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Specification 
APPARATUS AND METHOD FOR CREATION OP A USER 
DEFINABLE VIDEO DISPLAYED DOCUMENT SHOWING 
CHANGES IN REAL TIME DATA 

5 BACKGROmiD OF THR IMVEWTTQW 

The invention pertains to the field of application 
progreuns for monitoring and managing complex systems with 
many variables having values which vary in real time. More 
specifically, the invention pertains to the field of 
10 software systems which permit the user to create custom 
active documents with the layout, look and content defined 
by the user and displayed on a video display. Changes in 
the values of real time data which are included in the 
active document defined by the user axe reflected 
15 immediately on the display. 

In the mzuiagement of complex systems such as the 
finuicial community, airplanes, sonicohductor fabrication 
processes, etc. it is often useful for a user such as a 
financial trader to be able to look at only some subset of 
20 the total data available to him or her or to arrange the 
available data in a style which best suits the user's 
management and/ or analysis style. In the prior art for the 
financial community, the Quotron product fills some portion 
of this need, bu€ is inadequate in many respects. The 
25 Quotrbn product has a video display where three basic areas 
are available for customization by the user. One eirea is 
reserved for stock quotes where individual stock prices are 
displayed in a blocdc. The use^ can customize to the extent 
of defining which of the many stocks for which quotes are 
30 desired. The current price of the stock is then displayed 
in each block or window devoted to that stock by network 
access of a service that provides, stock quotes. Changes in 
the stock price are reflected on the display when they 
occur. Another area of the display is reserved for so- 
35 called "tickers", i.e., strezuns of trade data for various 
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stocks defined by the user with the stream for all the trade 
data moving across a common window. A third area of the 
display is reserved for a market monitor display where a 
plurality of stock prices are displayed as a group in a 
5 single window. With the contpnt of the group, i.e., the 
stock prices selected for display selected by the user. 

The Quotron product is inadecjuate in mamy respects. 
For example, it is useful for isi user to be able to be able 
to define a multi-sheet, completely custom document with 

10 whatever data he or she desires on each sheet arranged in 
whatever groupings, locations, format, color, font, pen 
desired with changes in real^- time data being reflected 
immediately on the display. Further, it is useful for the 
user to be able to set upper ^d/or lower alarm limits for 

15 any or all real time data displayed on any sheet and to 
define scripts of actions to t^Jce if the value of the real 
time data exceeds these limits.^ Further, it is useful to be 
able to publis]ti any or all thL(| data shown on any sheet of 
the active document on a network Ito which other users and/or 

20 automated processes are coupled via their respective hosts. 
Finally, it is useful to be a^le^ for a user to define and 
layout certain areas which will^ appear on all sheets such as 
one to f oiir margins, headers bi^ footers with text, a common 
"button" or a set of button^/fri.e. , display objects with 

25 user programmable text labels and a "push" operation with a 
programmable action which occuri every time upon a "push" of 
the button such as by selection of the button with a mouse, 
touch screen, voice designation or by the keyboard etc. 

SUMMARY OF THE INVEHTIQN 

30 An appeuratus and method according to the teachings of 

the invention provides a computer facility (hereafter the 
application or program) whereby a user, using a collection 
of layout tools may define an active document. "Active 
document" as that term is used herein means a video 

35 displayed document of one or more "sheets" of the user's 
design which incorporates text, displays of real time data 
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in user definable style, e.g» , color, font, background, pen 
size etc. and format, e.g., quote, ticker, graph etc., 
alarms, and alarm scripts, i.e., user defined scripts of 
cosimands to be processed (much like a word processing or 
5 spreadsheet macro) when an alarm limit is exceeded. The 
program automatically accesses the network to which the host 
is connected through network interface software which 
establishes the proper subscriptions for the desired real 
time data with the appropriate information service and the 
10 server upon which this service process ' is running. Real 
time data is then passed to the program from whatever 
network communication process is being used and is 
immediately displayed in the format, style and location 
previously specified by the user. Although the invention 
15 will hereafter be described in the preferred embodiment for 
use in a financial environment such as a trading floor of a 
broker such as Dean Witter etc., the^ invention is not 
limited to such applications. Any cdmplex system which 
generates real time data which control operators must 
20 monitor are subject to being monitored and controlled using 
the teachings of the invention* r 

The user defines each sheet of the document using a 
variety of tools which can be used to create display objects 
such as simple quotes or tickers to sophj}8ticated graphs and 
25 tables. The user may also use the tools to create text 
fields such as customized help screehilr which help other 
users understand the active document which has been created. 
All the tools share a common set of commands which are 
located in an menu typically displayed at the top of each 
30 sheet. Preferably, the tools are symbolized by icons and 
the menu options, when invoked, cause pop-up menus to appear 
with other options. The menu options are used to set the 
symbols for stock prices to be monitored, chsmging display 
characteristics and selecting which of the multiple pages to 
35 view. The location and type of menu display and the 
location and type of system used to display and/ or invoke 
the layout tools is not critical to the invention. 
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Similarly, the type of input device used to select tools, 
specify locations, specify symbols or the source of real 
time data to display at any particular display object, or to 
direct the program where on a sheet to display a particular 
5 display object , is not critical? to the invention. A mouse, 
trackball, digitizer, keyboard, voice processor and map 
coordinate system, touchscreen, or any other present or 
future deyice may be used such^as a thought processor. 

The tools provide access to information from any source 

10 including other programs minniiig on the same host 

0 or somewhere else on the network, ticker plants, 
information services or databases. In the preferred 
embodiment, the program can support data feeds from Reuters 
Market Feed 2000/IDN, Telekurs Ticker, CMQ felerate 

15 HarketFeed, Canquote, and Qup^pn. In addition, the program 
(known commercially as the MarketSheet" facility or program) 
can accept prices extracted f^om paged market data feeds 
Budh Teleraie TDPF, Reuters^ RDCapF, FBI and RKJ^J These 
types of data are first extracted lyf Page Shredder,f pother 

20 program - available from the;, ^ assignee of the ^present 

invention. t €^ 

In the pj^sfeirred embodiment, the tools available for 
defining an active document a^e as follows. A label tool 
allows the user to enter static text to label or annotate 

25 the active document or to creatfe his or her own personalized 
help screens. A quote tools displays the value of an issue, 
including a user defined set of other fields pertaining to 
that particular company in a display style specified by the 
user. For exaonple, a brief style displays only the price 

30 where a caii«>rehensive style -displays all the available 
fields. A ticker tool can be used as a selective or block 
ticker, and can show data in any display style, l^tidks and 
Downticks can be shown in coldr and volume information can 
be included. A page fragment :^ tool displays a region of a 

35 page-based feed such as Telerate or Reuters. Any region of 
the page designated by the user can be displayed from a 
single character to a full page. Highlighting modes are 
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provided to highlight that has changed. A time based graph 
tool can be ;ed to create graph display objects to 
graphically display the changes in value of a variable such 
as price per time. The time and price axes may be scaled to 
5 minutes or seconds, and the price value may be set to any 
unit such as 1/8 or 1/32 of a dollar* Above and below 
chsuinel segments can be drawn on the graph. Graphs may be 
merged to show two issues against the saune time cucis. A 
data set graph tool can be used to create graph display 
10 objects -which display the values of multiplet instruments 
such as stocks or bonds or other subscribed values in real 
me t such as a yield curve in a semiconductor processing 
application environment. Graphs may be merged to show two 
different sets of issues against each other to indicate 
15 market opportunities. A table tool can Isfe used to create 
display objects which show position blotters, currency 
lookup teUbles, and names of commonly used pages securities. 
A i>ublisher tool publishes information constructed using the 
program of the inviention or entered the user onto the 
20 network using the network commimication process running in 
the environment in which the program or process of the 
invention is running. The published inf onlation can be used 
by lother processes linked Tto the network %r as a bulletin 
bo^iird: for use livy her traders. A button tobl caxx be used to 
25 crefate splay objects that execute scripted actions when the 
button is "pushed**. I.e., selected in cmy ;way on the splay 
such as by clicking on the button by a mouse. The scripted 
actions are entered by the user in whatever sequence is 
desired in a language such as the MarketScript™ commamd 
30 language comprised of all commands at the program according 
to the teachings of the invention can execute. In the 
prefezrred embodiment, the scripted command sequence can also 
include commands to the operating system, the network 
communication software and other processes running on the 
35 same host or elsewhere on network. Buttons can be 
programmed to carry out commonly performed operations such 
as moving quickly to an important page or performing an 
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operation to be carried out when an alert condition occurs. 
The buttons allow creation of hypertext links between 
different sheets, and the alert scripts can perform 
operations such as changing a color, flashing an obiect, 
5 sounding an audible alarm or executing an external program. 
The latter capability provides great flexibility by enabling 
clients to program features such as the ability to telephone 
a beeper service when an alert occurs. A "glossary" 
facility allows users to add he«^ operations, i.e. / commands, 

10 to the scripting language and customize the menus as needed. 

For ease of learning the system, new users are 
supported by providing short arid full menu sets. New users 
can use the short set while working with existing tenqplates 
and tutorial files. After the System has been learned, the 

15 user can graduate to the full mianu set. 

In the preferred enbodiment, the program is used in a 
distributed system ar<dxitecture embodied in a local area 
network cot^ling workstations " and personal computers such 
. that the right amount of prodelsing power can be dedicated 

20 to each user and applicationr The distributed system 
architecture 'also allows critical applications to be 
supported by redundant or compleanentary equipment sudh that 
the system isrsufficiently reS^ continue to <^er&t&' 

even if a market data feed or server "should fail. 

25 In the preferred embodiment, the program according to 

the teachings of the invention? is ported to work with the 
TIB™ suite of network communication programs available from 
the Tetaiekron Software systems in Palo Alto, California. 
The TIB software is described in U.S. patent applications 

30 having serial numbers 386,5^4 filed JUly 27, 1989; 
07/601,117 filed October 22, 1990; and 07/632,535 filed 
December 21, 1990, which are hereby incorporated by 
reference. The TIB software supports siabject based 
addressing, network architecttire decoupling, communication 

35 protocol decoupling, data decoupling and separation of 
information sources from consumers. The TIB software 
subject based addressing capability frees applications such 
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as the program according to the teachings of the invention 
from the need to know exactly where on the network 
information of a particular type cem be obtained. For 
example, a trader cem reference "long bond yield" as the 
5 subject of a desired real time data subscription without the 
need to know the specific physical location on a specific 
page of a specific information service running on a specific 
server. Then, if the source of the information changes, 
users need not chemge their screens and progreunmers need not 
10 change their programs. 

The sepauration of information sources and consumers 
allows users to add or change market data sources without 
changing the application that use the data. The users can 
also add and change applications without impact on the 
15 existing sources of information. For example, data values 
from fixed format pages of market data ceui be combined with 
data from elementized feeds in a realtime spreadsheet. The 
spreadsheet can compute a result, e.g;, the theoretical 
.value of a derivative security, Md publish it on the 
20 network through the TIB software. 'The program of the 
invention can then graph the value in i^eal time. None of 
these application programs need ever r be aware of the 
existence - or operation f of the others v;f^ New application 
programs can be added to a firm^s compiiting repertoire at 
25 any time, building on each other tp create a total 
information environment. V:, 

The menu of commands allows the user to display an 
index of the sheets which have been defined for a particular 
active document file, and to select the sheet to view. The 
30 menu options also include commands to msmage sheets and 
sheet files, and to control the appeeurahce of the display 
and the objects; within it. The menu also includes commands 
to resmrange the location of the display object windows or 
boxes (the term boxes will be used herein to avoid confusion 
35 with the term windows in which separate processes may be 
running in multitasking environment or DOS windows 
environments) . In the preferred embodiment, the display 
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object boxes nay be layered on top of each other, and the 
menu includes options to change the order of the layers and 
move any particular box to the top of a stack. In the 
preferred embodiment, only one sheet is shown on the display 
sat any particular time, but in alternative embodiments, 
several sheets may be shown in separate "windows" or layers 
on the display. 

pPTEF DESCRIPTION OF THE DR AWINGS: 

Figure l is a typical sheet layout in an active 
10 document containing one or more user defined sheets 
constructed with a program according to the teachings of the 
invention. 

Figure 2 is a state diagram for the normal and alert 
states to illustrate the operation of alert scriptik. 
15 Figure 3 is a diagram of (i typical environment in which 

the program of the invention operates. 

Figure 4 is an example 6t an instance of an Active 
Object class. 

Figure 5 illustrates how the properties of Active 
20 Object are stored as data s^ructureJs in memory, and how 
libraries of programs are linked to these data structures to 
carry out the operations associated with each instance of an 
Active object. 

Figure 6 is a block diagram of the parts of a program 
25 according to the teachings of the invention, and the 
components of the coinputing environment in whidh the 
program, according to the teachings of the invention, 
operates. ; 

Figure 7 is a block diagram of the parts of an Active 

30 Object. 

Figure 8 is a flow diagram of processing after a real 
time data update. 

Figure 9 is a diagram oi event processing flow in a 
program according to the teachings of the invention. 
35 Figure 10 is a drawing illustrating the basic display 

of a program according to the teachings of the invention. 
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Figure 11 is an illustration of the menu bar. 
Figure 12 is a dialog box example. 

Figure 13 is an exaunple of the pull-down sheet menu. 
Figure 14 is an exeunple of the dialog box to select the 
5 index of interest. 

Figure 15 is the tools icon menu. 

Figure 16 is an exeunple of how the display for an 
Active Object changes when the object has been selected. 

Figure 17 is an example of y the display for multiple 
10 Active Objects when they have been selected. 

Figure 18 is an example of an object which has been 
selected by keybozurd transversal.^ 

Figure 19 is £ui exanqple of overlapped Active Objects. 
Figure 20 shows the pull-down menu structure for all 
15 menu options on the menu bar* 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT : 

Referring to Figure 1, there -is shown one example of a 
. user defined sheet in an active document constructed using 
a program according to the teachings of the invention. At 
20 the top left comer of the sheets is the file name, in this 
case FOCUS, naming the file in which the active dociuaent of 
which the user prograxmed sheet ;^f Figure 1 is a part. A 
menu of commands, i.e. , functions which can be invoked by 
the user through whatever input device is being used, is 

25 shown at 12. In the preferred embodiment, the menu choices 
shown at 12 each "overlie" a "pop-up" menu displaying 
further command choices related to the overlying command 
choice. Those pop-up menus will be detailed in a later 
figure. The menu lets the user display an index of sheets 

30 within the active document and to select the sheet to view. 
The menu 12 also includes options to manage sheet 
programming and active document files. The menu 12 also 
includes commands to control the appearance of the display 
and the display objects associated with the Active Objects 

35 programmed by the user into a sheet. 

Icons representing the tools that are available to the 
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user to define the Active objects which are to appear on any- 
particular sheet of an active document are shown at 13. 
Each tool, when invoked, allows? the user to create an Active 
Object on the programmable portion of the display at a 
5 location specified by the user using some input device. 
Eadh tool can be used to define an instance of a particular 
class of Active Objects or to canry out an operation such as 
publish or display a grid for > alignment or layout of the 
sheet. The general classes o^ Active Objects are labels > 

10 quotes, tickers, time graphs, <iata set 

i graphs, page segments and buttons. The tools may also be 
invoked by name^ rather than graphically by selecting an icon 
representing that tool using a pointing device. Further 
description of the various tools will be provided below. 

15 the user programmable display area proper is shown at 
14. At the top of the display eurea in this example, the 
user has created an instance ±6 of a label class Active 
Object with text entered by'ttie user to define what the 
particular sheet being displayed is. This' label Active 

20 Object was created by invoking the label tool represented by 

icon 15. *" 

The program according to the teachings of ^the invention 
use pbjected driented prcigrkikiLn.^ sl^le. lAlithough the 
- preferred embodiment of a progiram according to the teachings 

25 of the invention has been written in C language for easier 
portabilil^ among macdiines usin|f programming conventions to 
make the C language act like an object oriented programming 
language, it is easier to construct the program using object 
oriented programming languages such as C++. 

30 Mie middle " of the display " area coritaiins several 

instances of quote class Active Objects in different display 
formats generated by invoking the quote tool represented by 
icon 17. Each three, four, or five letter individual symbol 
in the box 18 and the number? next to it represents an 

35 individual quote where the user specified the symbol based 
upon the stock issue he or she wanted to monitor. 

The middle of the display also shows an instsmce 20 of 
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a ticker class Active Object showing all trades in a 
specified set of issues that exceed a minimiim volume set by 
the user. This particular criteria for display was 
progranuned by the user using the ticker tool represented by 
5 icon 19. 

At the bottom of the display is an instance 22 of a 
igraph class of Active Object. The program allows graphing 
of trades, volumes, spreads, indexes or any other value. 
Two different types of graph tools are provided although 
10 only graph icon 21 is shown in Figure l. In the preferred 
embodiment, another graph icon is present in area 13 
representing a tool to create Active Object instances of 
data set graphs. These types of graphs are usually bar 
graphs where each har represents some real time value about 
15 a different stock issue designated by th^ user although in 
different embodiments, each bar can represent the real time 
value of any variable in a complex system> 

An instance of a user designated portion of a stsmdard 
financial page such as Telerate, page 8. has been created at 
20 24 using the page fragment tool represented hy icon 26. 

"Active document" as that term is .used herein means a 
video displayed document of one or more "sheets" of the 
user^s design irtiich incorporates text, di^lays of real: time 
data in user definable style, e.g., color, font, background, 
25 pen size etc. and format, e.g., quote, ticker, graph etc., 
alarms, and alarm scripts, i.e., user defined scripts of 
qommands to be processed (much IdLke a word processing or 
spreadsheet macro) when an alarm limit is exceeded. The 
program automatically accesses the network to which the host 
30 is connected through network interface software which 
establishes the proper subscriptions for the desired real 
time data with the appropriate information service and the 
server upon which this service process is running. Real 
time data is then passed to the progr^ from whatever 
35 network communication process is being used and is 
immediately displayed in the format, style and location 
previously specified by the user. Although the invention 



wo 92/12488 



, PCr/US91/09811 



- 12 - 

will hereafter be described in the preferred embodiment for 
• use in a financial environment such as a trading floor of a 
broker such as Dean Witter etc., the invention is not 
limited to such applications/ Any complex system whicA 
5 generates real time data which control operators must 
monitor are subject to being monitored and controlled using 
the teachings of the invention^. 

The attributes of the Actifve Objects which are used to 
compose an active document arenas follows. 

10 A label Active Object is jl^t a fixed character string 

placed in a position on a sheet entered by the user. Labels 
are used to identify sheets, regions on sheets, and 
individiial monitoring Active Objects as well as in script 
files to generate messages ii^en an alarm event occurs or to 

15 generate custoiaized help screien for a pzortiicular active 
document. A label does not change in real time. Its 
attributes are: String (field) which is the text string to 
be displayed in the label oB|ect; and, Aligiment ; (radio 
button list) which is one of i three formatting options - 

20 left, center and right. 

A quote object is a familiar market price quotation* 
Any number of quotes may be plaB^d on a sheet. Attribiites of 
the particular" instance recordplfor a quote Active, Object 
determine not only what issue is: quoted, but also what items 

25 of information from the total ^rcomprehensive record for a 
particular issue eure displayed. Different types of quotes 
may have different formats. Th^ attributes of a quote are: 

• Market Type (list) 

DefdLnes the type of 'information being received 
from the soiurce in this quote > such as equity, 
option, future or shredder output. This choice is 
used to determine the information source, the 
available stT/les and the internal record formats. 

• Display Style (list) f 
Defines what display format is to be used for this 
quote. Each market type has one or more styles 



30 



35 
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defined, which typically show different 
collections of fields from the received 
information. Host market types have a **brief*' or 
"regular" style, which shows simply symbol and 
5 price information, and other styles may also be 

present which show more detail. 
• BjwlboL (field) 

Defines the specific symbol, i^e., stock, to be 
used for this quote instance. The symbol may have 
10 a suffix which indicates the exchange to use. 

These suffixes may be translated into a longer 
exchange name through tremslations set up by the 
System Administrator. Also note that for user 
convenience, character entered will automatically 
15 be put into upper case (if lower case letters are 

needed, such as for a class or warrant, the shift 
key cam be used). 
. . • Alert rield (command button) ^ 

Pops up a dialog box containing ^ a list of numeric 
20 fields in records for this market type. Used to 

select which field to use in alert calculations. 
This dialog box also contains ei^eas to enter four 
different scripts, which au:^ executed under 
different conditions, as explained below. 
25 • Limits (2 buttons and fields) 

These are used to set above and below limits for 
an alesrt. Also, the above and below limits can be 
activated and deactivated by clicking on the check 
boxes. When the value of the real time data goes 
30 above or below the limits, the object is shown in 

reverse video. 
The choices listed in the Market Type and Style lists 
sure defined in configuration files. Other types and styles 
can be set up by the System Administrator. 
35 (2uote objects are traversable, which means that the 

user can transverse to the quote object and enter a new 
symbol simply by entering it from the keyboard. 
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Quo'tes have four different scripts which are run for 
different' reasons with respect to alerts. Figxire 2 
illustrates states behind this concept. A quote is either 
in the normal state 26 or the alert state 28. When a real 
5 tine data update comes into a ;normal state quote and does 
not trigger an alert, the "normal update" script is run. A 
script is a tiser defined string of commands that are 
executed in sequence. They can: be commeuids that the progrcua 
of the invention understands,;: commands to the operating 
10 system or other processes operating in the environment or 
commands to any other process running anywhere else on the 
network. The script language also has a glossary facility 
whereby the user can define new commands and add them to the 
script language. When an update comes in which triggers an 
15 alert, the "begin alert" script 30 is run. This script 
takes the quote object into the alert state 28 where the 
"alert update" script is run. Additional updates which are 
in the alert run will continue to rtm the "alert update" 
script. Then when an update cd»mes in which is back in the 
20 normal range, the "end alert" -script will be run, followed 
by the "normal update script;-.^ ^ Thus, the four scripts 
provide a way of checking for changes in the state, or for 
staying in the ^ame state. ^.f :. 

The ticker tool £s a continuously shifting display of 
25 trades in a specified list of issues. In additiph to 
attributes, the dialog box for a ticker displays the current 
list of securities being tracked and some commands for 
manipulating the list. The dialog box is used to chaoige or 
add to the securities on the list. The ticker attributes 
30 are: 

• Create (comnand button) 

Adds a security to the list. A mouse click on a 
.Create Button, i.e., tlie icon 19 in Figure 1, will 
cause the Siibscription Entry dialog box to appear. 
35 The subscription for t^e desired real time data is 

edited using the dialog box and is completed with 
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a mouse click on the OK button. Another 
subscription can be entered with zmother click on 
the Ticker icon 19 • 

• Delate (coBBand button) 

5 Deletes the currently selected item from the list. 

• Edit (oommand button) 

To edit items which are already on the list, one 
pointing device click on the item selects it. 
Then a click on the Edit button, and the 
10 Subscription entry dialog box will appear. 

• Copy From (command button) 

Replaces the current ticker list with a copy of 
the one from another ticker. A dialog box will 
pop up requesting the name of the source ticker. 
15 • Add From (command button) 

Like Copy From but adds to the curirent ticker list 
instead of replacing it. 
f Name Sbrt (button) 

Sorts the securities listed in the selection list 
20 by their symbol names. 

? Type Sort (button) 

Soxrbs the securities listed in the selection -list 
^ by their market type. 

The subscription entry dialog for the ticker tool is as 
25 follows: 

• Market Type (list) 

Used to select the Market Type for the security. 

• Ticker Style (list) 

Used to select the display format for trades or 
30 „ updates to the ticker subscription instance. 

There are generally several styles, similar to 
those defined for the Quote object. The styles 
are generally different for the different market 
types. 

35 • symbol (field) 

Used to enter the security symbol. The szune 
conventions are used as for entering the symbol 
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into -the Quote dialog box. 
• Voltoie (field) 

the minimum number , of shares in trades to be 
displayed. Note thkt this dialog box field will 
5 only be shown for Karket Types which have an 

associated volume .ifield. For instance, most 
equity fields have a volume but RTSS results do 
not. 

A- 

Composite or "wild card" pickers can be created simply 

10 by entering for the symbol a period followed by the name of 
the exchange code. The ticker object will then show every 
update reported by the feed on that excheuige. 

The ticker object will show new data each time it 
receives an update from the da^a feed which includes either 

15 a new volume value, or a new value for one of the fields in 
the specified style. Thus, if the display style shows the 
symbol, the last price, and the trade volume, updates will 
appear when there is a change of the last price or the trade 
'volume. If the display style ^>hows the symbol and the bid 

20 and ask price, updates will appesur when there is a chancre of 
the bid price, ask price, or the volume field. In this way, 
the ticker can/ hsmdle inf ormajl^bn from: sources which do not 
have the standard field, such 'as output from the Shredder, 
an application that element izes data which is provided by a 

25 service only in standeurd "packages" such as Telerate pages 
etc. 

The Page Fragment tool, represented in Figure 1 by the 
icon 26, is a user selecteible rectzmgular section of a page 
from a page-based market data service. The user constructs 

30 a page fragment interactively, using a pointing device to 
designate the fragment to be extracted and its destination 
on the sheet being composed. This can be done starting from 
a page-abased service application, or entirely within the 
progiram of the invention. The user can then modify these 

35 and other attributes using the page fragment dialog box and 
the menu commsmds. 
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To in2ike a page fragment Active Object to be displayed, 
the following process is performed: 

1. Hove the ctursor to a window, i.e., a page-based 
display, containing the source page. 
5 2. Position the cursor at the upper left corner of 

the region the user wish to select. 
3 • Click and hold down the left mouse button and move 
the cursor to the right and down to the lower 
right comer of the region the user wishes to 
10 select. The fragment can bf as small as two 

characters or as large as the entire page. 

4. Release the mouse button. ^The fragment will 
appear in reverse video. 

5. Select the Page Fragment tool from the toolbox by 
15 clicking on icon 26 or typing the name of the tool 

or using any other input device to select the 
tool. 

6. Click the mouse button where the page fragment is 
to be located on the sheet being composed and drag 

20 to the lower right. i 

■ — ■• 

To medce a page fragment with no source page; 
^ 1* Select the Page ^Fragment tooL^rom the toolbox. 
2 4 Drag the region where the page fragment is to be 
positioned on the sheet being composed. 
25 3. The page fragment will be blank except for the 

title. Use the dialog box to define the service, 
page and region to be displayed in the page 
fragment. The default region will be the full 
page. 

30 The dialog box for a page fragment will display the 

full source page, and draw the region being extracted for 
the fragment. The program according to the teachings of the 
invention draws display objects by invoking the functions of 
the commercially available XWINDOWS system in 5 titie 

35 preferred embodiment although other embodiments can be 
ported to any other commercially avail2d>le or research 
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screen rendering library, program or toolbox. The XWINDOWS 
system is available from a consortium of vmiversities and 
commercial vendors known to those skilled o in the art. To 
change the region in which the page fragment is displayed, 
5 the mouse or pointing device can be used to designate the 
upper left comer of the new region, and then drag to the 
lower right comer. The dialog box can also be used to set 
the following attributes: | 

• Service (field) f 

10 The name of the page-basied source, such as Telerate. 

Clicdc on this field to bring up a dialog box to change 
the service. If zmother page fragment is also 
displaying that service and page, it will be 
immediately shown in fulli source page display. If not, 

15 the user must confirm thje dialog box to revest the 

page from the service. 

• Page (field) 

Page Number (or neme), such as 7677. Click on this 
field to bring up a dialoir box to chemge the page. If 
20 another page fragment is lalso displaying that service 

and page, it will be immediately shown in full source 
page display. If not, the^^user must confirm the dialog 
box to reijuest the page ^om the service. f 

• Title Position (radio biit1;on list) 

25 Used to specif y that ther#: should be no title> or that 

there should be a title indicating the service and page 
number^ and the highlighting mode. The default is that 
there is no title, in o?:der to pacdc page fragments 
closely together. 
30 Page Fragments are traversable. The user can traverse 

to a page fragment object, arid enter a new page name or 
number simply by typing it from the keyboard. 

The Graph tool allows creation of graph Active Objects 
with associated display objec1;s which tracdc the real time 
35 variations in a variable in a complex system such as market 
value. The graph object is a composite of several simpler 
objects: a graph/time axis, a price axis, and a graph area. 
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Each of these areas can be Independently selected for 
changes to colors, fonts, and borders. The outermost 
portion is the frame for all of the graph sub-objects, and 
must be selected in order to perform edit operations such as 
5 move, resize, or front/back restacking operations. 

Each axis has its own attributes controlled by a 
separate dialog box. Because the graph object is a composite 
object, it may not be duplicated with the Duplicate tool. 
When the user clicks and holds a mouse fciutton anywhere 
10 inside the graph area, the value for the Price Axis is shown 
in the upper left hand corner of the Graph Display Area and 
the value f or the Time Axis is shown in the upper right hand 
corner. This feature is useful in identifying numeric 
values for any point on the Graph Lines. 
15 The Graph/Time axis dialog box allows the user to edit 

attributes of the overall graph as well as the attributes of 
the times axis. The attributes this dialog box currently 
supports are divided into the following categories. 

BCaOiZNO ATTOXBUSBS 

20* Type (radio button list) 

- «-> 

Selects the type of time axis. The time iixis currently 
^support two types of scales: time sisi ticks. The 
'default is time. 
• Precision (radio button list) 

When the scale type is set to time, the precision of 
the scale mark labels can be set to minutes or seconds. 
When the scale is set to ticks, precision is not 
adjustable. 

Lock Seal* (option button) 

freezes the time axis minimum and maximum values to 
their current settings, disabling automatic rescaling. 
When this option has been selected, a lock icon will be 
shown on the axis. 



25 



30 



THOB AZZ8 LZNZT ATTRIBUTES 
35 • Maximum (field) 
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The upper limit of the time scale. 

• Minimxu (field) 

The lower limit of the time scale. 

• Step Value (field) 

5 The increment to show when drawing hash marks and 

numbers on the time axis. Axis limits can be cheuiged 
manually in the dialog box or can be chstnged using 
scaling commemds 

• Drav Grid Lines (option bujbton) 

10 If selected, the tick marks on the times axis are drawn 

across the graph area. 

CHUACnERiSTZCS 

Axis Position (radio button list) : selects position of 
time axis as either above pr below the graph area. 
15 • Hew Price Axis (command button) 

creates a new additional price axis and positions it to 
the right of the existing axis. 

GRAPH PRICE AXIS 

Each graph can one .oi^~'^inore , price axis, fach 
20 corresponding to a different, instru&ent being graphed. 

HAlfiB 

• 8]pabol Itaae (field) 

Defines the specific symbol to be used for this price 
axis, such as IBM or GOLD. This may be followed by an 
25 exchemge code. The same conventions used in the Quote 

symbol name apply here. 

V 

PRICE AXIS LIMITS 

• Max Value (field) 

Upper limit of price scale. 
30 • Min value (field) 

Low limit of price scale. ; 

• Step Value (field) 

The incnrement to show when drawing hash marks and 



wo 92/12488 



PCr/US91/09811 



- 2i - 

nvmbers on the price axis. Axis limits can be changed 
manually in the dialog box or can be changed using 
scaling commands. 

• Draw Grid Lines (option button) 

5 If selected, the tick marks on the time axis are drawn 

across the graph area. 

PRICE AXIS COMMMIDS 

• Delete Axis (comaand button) 

Deletes the selected price axis unless it is the only 
10 price axis. 

• Copy Axis (command button) 

copies the selected price axis and places it on the 
screen to the right of the existing axes 

• Clear Trends (command button) 

15 removes all trend lines related to the current price 

axis 

Price Axi s Attributes 

• Line Width (field) 

determines the width of the Graph Plot Line. Width of 
20 0 i^is recommended for optimum repainting time • 

• Retain Count (field) 

tlie number of data points that are kept for the given 
as^is. The default is 150, this means that the system 
keeps track of the last 150 "ticks". Once 151 is 
25 plotted, the first tick is dropped off • 

• Point Size (field) 

the size of the Point drawn when a new data value is 
plotted. J,, 

• Precision (field) 

30 the number of decimal places to show oh the Price Axis 

(Y-*axis) has marks. 

• connect Points (radio button list) 

If "Yes", will draw lines between data points; If "No", 
will only plot data points (be sure to set Point Size 
35 to greater than 1 if lines aren't drami) . 

• Direction (radio button list) 
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places the current Price Axis on the Left or Right hand 
side (default is left). 

• Lock Scale (option button^ 

freezes the price axis minimum and maximiun values to 
5 their current settings, disabling automatic rescaling. 

When this option has been Selected, a lock icon will be 
shown on the axis. 

GBXBE TRBMD LIKES 

Trend Lines may be drawn on a graph to indicate support 
10 and resistance levels. ^ 

f 

CStSKTlXQ TO BHD LINES 

!• Move the cursor to the Pipint on the Graph where the 
Trend Line should begin. , 

2. Hold the Shift Key dowi^., and click the left mouse 
15 button. This creates one trend point. The user can 

move the trend point befpre releasing the button by 
moving the mouse to the desired location- 

3. Click the left mouse button a second time on the first 
trend point, hold it down, and drag the cursor to a 

20 second trend point. The usm: will see a temporary trend 

line "following" the mousei;:: cursor as the user dragis it 
into position. 

4. Release the Mouse. Button to complete the line. It will 
appear as :a dotted line. - 

25 miglKg T B^^ LTMBg 

• Insert Trend Points/segments 

Press and hold the left mouse button on one of the 
trend points. A new trend point will be created that 
can be dragged to the desired location. 
30 • Move Trend Point 

Press and hold the right mouse button on the trend 
point to be moved and dra^ it to the desired location. 

• Delete Trend Point 

Hold the shift key down, and click on the trend point 
35 with the right mouse button. 
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• Move Trend Line 

Hold down the Shift and Control keys together. Press 
and hold the right mouse button on any trend point on 
the line. Then drag the trend line to the desired 
5 location. 

DELBTIHQ TREND LINE8 

Hold down the Shift and Control keys together and click 
the left mouse button on and trend point on the line. 
All trend lines can be deleted .by using the clear 
10 trends command in the Price Axis Dialog Box. 

oaxm scALno 

The dynamic graph application provides very flexible 
scaling functions as follows: 

it- 

• Settable ain, max, and step values 

15 The minimum, meucimum, and step values of the axes can 

be set via the dialog boxes discussed in the Price Axis 
sections. They can also be changed via the rescaling 
methods described below (zooming^ and moving trend 
lines) . ^- 

20 • • Automatio Resoaling « - 

Axes can be rescaled automatically ^yhen new data points 
^ arrive. unless scale is fixed/v^the graph adjusts 
periodically to accommodate the current shape of the 
line. * 

25 • Fixed Scaling 

The automatic rescaling feature can be turned off by 
setting the lock scale attribute to true. This 
attribute can be set via the dialog box. 
• Zoom Function 

30 The graph object provides the capability to zoom in on 

a rectangular section of the graph. The same action 
can be accomplished by settdLng the axis limits 
manually, but it is much easier ^o perform such an 
operation using the mouse. To initiate a zoom, hold 

35 down the COmnROL key, click the LEFT mouse button at 

one comer of the desired zooming recteuigle, drag the 
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cursor to tlie opposite corner of the rectsoigle, and 
then release the button. The axes will rescale such 
that the specified rectangular viewing region takes up 
the whole graph viewing region. To zoom back such that 
5 all points are visible, hold down the CONTROL key and 

click the KEGHT mouse button anywhere on the graph view 
area. 

• Rescaling via trend line drawing 

There is a potentially useful side effect of drawing 
10 trend lines that can be utilized as a quick method for 

rescaling the axB& to the desired values. Mien 
dragging a trend line point, the user may move the 
point outside of the visible graph window. If the user 
releases the button while, t^e point is outside, jand the 
15 appropriate axes are not "^Pixed, " then the axes will 

rescale automatically to accommodate the new point 
within the graph area. Thus to extend the time axis 
further to the right, instead of changing the max value 
via the dialog box, the u^ser may move a trend line 
20 point the desired distance beyond the right boundary of 

the graph view. When tli|^ user releases the mouse 
button, the time axis will extend its scaling to 
include the; new trend line^^oxnt. 

. GRm A£BRT8 4 - 

25 The graph alert fadli^ provides a notification if a 

data point aoves outside a region defined by two active 
trend lines i; At any given tiae, at aost two trend lines can 
be active. If two trends are active, then activating a new 
trend line will deactivate the last recently activated trend 

30 line of the two. Activation and deactivation of trend lines 
is done via an abbreviated "move" trend point operation, 
i.e. clicking on any point of the trend line with the right 
mouse button without any mouse movement between press and 
release. Clicking on an inactive trend line activates it 

35 while clicking on an active trend line will deactivate it. 
An active trend line is drawn in the color of the graph plot 



wo 92/12488 



PCr/US91/09811 



- 25 - 

with which it is associated. Inactive trend lines appear in 
a lighter color. 

If two trend lines are active, any new point that comes 
in through the subscription will be checked to see if it 
5 falls between the values specified within the time range of 
thB two trend lines. An alert is triggered when a graphed 
value goes outside the bounds of the active trend lines. 
To use the alert facility: 

1. Hake sure the correct ' price axis is 
10 highlighted for the security for which the 

user wishes to set ah alert. 

2. Create two trend lines that define upper and 
lower limit ranges (a "channel") for the 
security. 

15 3. Activate the trend lines by clicking on any 

trend point with the right mouse button. An 
active trend line is shown as a dotted line 
the color of the graph plot line. An inactive 
trend line is shown as a lightly colored 

20 : line. The right mouse button is a toggle 

between active and inactive*. 

4. If the security value goes'iibove or below the 
channel formed by the twpf trend lines, the 
graph will alert. The alert is shown by the 

25 new trend point flashing as a large square. 

5. The alert will continue to %lash until a new 
trend point alerts, or if the user clicks on 
the alert with the left mouse button. 

There are two scripts associated with graph objects, 
30 one for normal updates and one for alexrt updates. 

BUTTOBT 

A button is an object which the user can interact with, 
and will cause a script to be carried out when clicked on. 
For instance, the button might perform the equivalent of a 
35 Sheet Next command, or transfer the us^ to a specific 
sheet. Buttons allow the user to determine the dynamic 
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action of the sheets, as well as their appearance. These 
scripts are expressed in the 5 MarketScript* language. 

Each button is created using the button tool, and the 
user can use the font fill, and pen menus to specify the 
5 appearance of the button (the border menu does not operate 
on buttons) • However, sinde a button carries out itis 
operation when clicked on with the left mouse button, the 
user must use the middle or right mouse buttons to bring up 
the dialog box to set the buttton attributes. The "Script** 
10 entry of the button dialog box allows the user to enter the 
script to be carried out* 

V..' ' 

: 

BUTTOH STYLES 

Style include rectanguleir, rounded, shadow, check box, 
and radio button. In most c^ses, the check box and radio 
15 button styles are used when there are groups of buttons. 
Note that for check box arid radio button styles, the 
aligiunent choice does not apply. 

SCRIPTING LANGUAGE 

Scripts are composed of one or more actions, w;hich are 
20 entered as a sequence. The potions can perform operations 
such as selection of objects,:^ editijig of selected objects, 
navigation to sheets, and editing of the current' sheet. 
Note that these commamds mus^; be entered exactly as shown 
with "respect to case. The Currently supported scripting 
25 commands are: 

Object Selection Commemds: 

all select selects all objects on 

current sheet 

none select selects no objects on 

30 current sheet 

self select selects the object which is 

running the script 
<item name> find select selects all items of given 

name 

35 <clas8_na]fie> class select I selects all times of given 

class 

<region_bound8> region select selects all items in region 
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10 



Editing of Selected Items: 
front 

back 

hide 
show 

/ clear highlight 



<color_najiie> pen 
<color_naiDe> border Color 
<integer> borderWidth 
<eolor_naiiie> f ill 
toggle visibility 



20 Move and Resize of Selected Items: 
<xXy> move . 



<dxXdy> move 
<widthXheight> size 
<dwid1:hXdheight> rsixe 



15 



25 



30 



35 



<x> alignLeft 
<y> alignRight 
<y> alignTop 
<y> alignBottom 



Sheet Navigation Commcmds: 
first sheet 
prev sheet 
40 next sheet 

last sheet 
index sheet 

<sheet name> find sheet 



restacks selected items to 
front 

restacks selected items to 
back 

hides selected items 
shows selected items 
dear highlight of selected 
page fragment objects 
sets pen color of selected 
items 

sets border color of 

selected items 

sets border width of 

selected^ items 

sets fill color of selected 

items 

inverts hide/show of 
selected items 

move of selected items to 

X/ y 

relative Imove of selected 

»>.-... 

items 

•resizes ' selected items to 
width, height 

relative 'i^esize of selected 
items 4 

aligns o^left edge of 
selected ^^items to x 
aligns fright edge of 
selected Items to x 
aligns top edge of selected 
items to y 

aligns bottom edge of 
selected items to y 

transfer to first sheet 
transfer to previous sheet 
transfer to next sheet 
transfer to last sheet 
active index dialog 
transfers to next sheet 
with given name. wraps 
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push sheet 



pop sheet 



10 



Editing of Curren't Sheet: 

<color_naiiie> baclcground 

on grldiiines 



15 



20 



off gridLines 
toggle gridLines 

Execution Control * 
beep 

<UNIX coiiiiiand> execute 



<inilli8econd8>. pause 



Environment Cohtrol: 
on toolBox 
25 off toolBox 

toggle ^toolBox 



30 



on gridTool 
off gridTool 
toggle gridxbol 



'x 



back to front if needed, 
beeps xf luune not found, 
pushes current sheet onto 
stack 

pops entry off of sheet 
stack and goes to that 
sheet 

sets sheet color background 

to named color 

turns on drawing of 

gridlines 

turns off drawing of 
gridlines 

toggles the drawixig of 
gridlines 

beeps the workstation 
runs UNIX command in 
background 

pause for specified amount 
of time 

» ■ 

shows the toolbox 

hides the toolbox 

inverts hide/show sense of. 

toolbox 

turns on grid tool 
"turns "off grid tool 
toggles activation of grid 

tool ^ £ 



SCRZSTZNa 

You will find the sheet ^^pper at ions most useful when 
CTeating new traveirsal options on a set of sheets. Olie 

35 "find sheet" command is most useful to transfer to a 
specific sheet, and will search from the first sheet to the 
last to find one which matches the give name. 

The object selection commamds provide ways to select 
all objects, no objects, all ^of a given class, all of a 

40 given name, or all in a region. For instance, if the user 
created a set of Quote objects, and had some display 
elements of the Dow- Jones Industrials and the others display 
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the Dow- Jones Utilities, assign the name '*INDU" to all of 
one group, and assign the name *'DTIL" to the other group • 

Then use a button script of "INDU find select red fill** 
to turn all of the Industrials red^ and **DTIL find select 
5 blue fill" to turn all of the Utilities blue tander button 
control. Another useful example would be to use '^Quote 
class select green fill** to chemge all quotes to have a 
green fill color. 

A common use of scripts and' pop-up objects is to 

10 annotate a sheet with a number of e^ctra label objects which 
describe what is being monitored or graphed. Make sure that 
the label objects are in front of ^the other objects, and 
then give them all the name •■DETAIL** . Now create a button 
with the script **DETAIL find si^lect show**, and another with 

15 the script ••DETAIL find select hide>*. Executing these two 
buttons will turn the detail on and'^off on your sheet. 

SCRZPTIHO NOTES 

If an item name, sheet neune^ iconmaind, or color naoae 
cbntains a space, it must be contained within quotation 

20 marks. Either single or double quotes may be used. Names 
containing single quotes may be conikined in double quotes, 
and vice versa. v 

When setting up alert scripts for a group of Quotes, 
set up the scripts on tll^ "first' t)hej emd then use the 

25 Duplicate tool to make the others.' The scripts will be 
copied into each olie made. ^ - - - I 

There are roughly 80 pixels per inch on a workstation 
screen. All of the x, y, width, and; height measures in the 
scripting Izmguage are in pixels. 

30 It is common for scripts to select objects to operate 

on, but if scripts are run at unexpected times (such as due 
to Quote updates) , they could change the selection status of 
the objects the user is trying to edit. For this reason, 
the selection status of the objects is saved at the start of 

35 the script execution, and is restored afterwards. Thus if 
a script begins with an ""all select** phrase, it is not 
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necessary to end with a "none select phrase". 

Referring to Figure 3, there is shown a typical network 
environment in which the preferred embodiment of the 
invention would be employed. Element ized data feeds are 
5 received via a lAN/WAN (Locfil Area Network/Wide Area 
Network) 32 and handled by a fe4d handler 34. Paged market 
feeds are received via the network 32 and handled by a feed 
handler 36. A workstation 38, running a shredder process 
breaks up the pages of the paged feeds into their 

10 constituent elements. A workstation 40 running a program 
according to the teachings of the invention is used by a 
user to ccnnpose an Active Document to manage financial 
information in real time. As €he various quotes, tickers, 
graphs etc. are created, subscription requests for the 

15 required data sure passed to ' ' the network communication 
software running on the workstation 40. If the Tlk* network 
communication software is being used, the siibscription 
requests are filled using subject based ad<teesslng. The 
subscription requests result i|{, properly formatted seErvice 

20 request transmissions on the '^etwork 32 to l|he proper 
service amd server in the proper _ protocol to request the 
desired data. The server or s'e^^s then tremsmit the data 
back to the workstation 40 wh|re it is displayed in the 
Active Document defined by the user. 

25 Itef erring to Figure 4^ tiiere is shown a typical ekample 

of an wobject* as that term is used in the object oriented 
programming*^ world. ^ object' is aii entfty which has both 
properties and associated operations which oan be invoked by 
a user to change the values of various properties of the 

30 object. In the simple example chosen, the object is an 
entity representing a class of objects in the form of bank 
accounts. The particular instance in this class is a bank 
account for Jessica Doe. The properties of each object in 
this class are the account number, the balance and the owner 

35 name. The operations that can i be invoked are withdrawal, 
deposit and query. Each operation can be invoked by 
entering a command to identify the object and start the 
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operation (typically the name of the operation) followed by 
' the argiunent. The operation then uses the argument to 
change the properties of the object. For example, the 
commeuid Doe. Deposit (100) would invoke the deposit operation 
5 and add 100 units to the balamce property of the Doe bamk 
account. 

Typically, an object is represented in memory by a 
record containing the values for each of the properties and 
a link or pointer to a librzury of programs which ceorzy out 

10 the operations associated with that object. This structure 
is shown in Figure 5. In Figure 5, two data records 42 and 
44 represent the values of the properties for two instance 
of bank account class objects. Each Record has a link or 
pointer, 46 and 48, respectively, to a library 50 of 

15 programs which carry out the operations associated with this 
class of objects. 

Referring to Figure 6, there is stiown a diagraua of ^the 
hierarchy of the parts of a typical proffram according to the 
teachings of the invention. A Frame pbject 52 *icontains» 

20 all the other Active Objects that vill*|i^ manipulated by^the 
system. The Frame Object contains melius, dialog boxes and 
exactly one Active Dociiment. The mehuk eure comprised of a 
menu system 54 and a plurality of |menu objects sliown 
generally at 56. The menu system 54 handles user inputs 

25 from whatever input device is being used for selection of" 
commands, i.e., menu options. The dialog boxes are 
implemented by a dialog manager 58 todf a series bf dialog 
objects shown generally at 60. The dialog manager 58 
handles user input associated with user Cselection of desired 

30 values for editing properties of Active Object instances 
which have been created on a Sheet using a tool. It is also 
used to specify commemds which are specific to certain types 
of Active Objects. Generally, the menu options shown at 12 
in Figure 1 are generic operations which can be applied to 

35 any Active Object. However, certain Active Objects have 
associated properties and operations which are specific to 
that class of Active Object alone. These specific 
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properties and operations are unbodied in the instances of 
dialog objects shown at 60 in Figure 6. For each class of 
Active Object which has specific properties and operations, 
there is one or more dialog object(s) which can be used in 
5 a user dialog to set specific properties of an ^Instance of 
that class of Active Object and to invoke operations which 
are specific to that class of Active Object. A graph class 
of Active Object is an exam^jle of a type of Active Object 
^ibh has more than one dialog box. Thiere is one dialog box 
10 to set the properties of the x-axis and one dialog box to 
set the properties of the Y-axis. Some of these dialog 
boxes "pop-up" supplementary" dialog boxes. 

An Active Document object 62 "contains" a plurali"^ of 
other objects. They are: a pturali^ of Sheet Objects which 
15 have been composed by the iifeer using the tools described 
above and shown generally St 64; a plurality of Active 
Objects the instances of which are creatied tising the tools 
desnibed above and shown generally at 66; emd groiq> objects 
^owii generally at 68. <|roup objects are essentially 
20 "containers" for other objects and can contain, a plurality 
"of Active dbjects such alT are showrr generally at 70- 
instances of which are created using the tools, |and one or 
" more other' group objects^ shb<^ generally at 72 eaish of' which 
may contain a plurality of Active Objects such as shown at 
25 74 or other group objects such as are shown at 76. 

Some of the -properties of each Sheet Obj^ect -sore: . 
whether a grid used for alignment of various Active Objects 
thereon is or is not displayed; grid size; background fill 
pattern, e.g., solid blue, dollar signs, etc.; a list of 
30 contained objects; scripts associated with the Sheet that 
handle alerts for any objects' on the Sheet; i^ether the grid 
is being used; edit mode status, i.e., idiether the user will 
be allowed to edit (unlocked) or not be allowed to edit 
(locked) the Active Document; etc. Some of the 
35 operations/commMds associated with each Sheet object are: 
toggle grid setting; chemge grid size; chernge background 
fill pattern; align an Active, Object to the grid; change the 
r • - 
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edit node status; etc. 

The Active Document object 62 has various properties 

including: the current Sheet to display; the list of Sheets 

in the Active Document; the file name iinder which the Active 
5 Document is stored; the number of Sheets; etc. Some of the 

associated operations include: open an Active Document file; 

add a Sheet or Sheets from another Active Doctiment to this 

Active Document; close an Active Document file with save or 

do not save options; go to next Sheet; go to previous Sheet; 
10 etc. r 

The properties and operations associated with each 

Active Object on a Sheet are as defined above in the 

descriptions of Active Objects created with the tools. 

The pop'up or pull-down menus ^tinder the main menu 
15 options of the menu bar are menu objects as are the main 

menu options of menu bar 12 in Figure a. 
« The dialog manager 58 insures that the proper dialog 

r object is selected to medce the proper dialog box appear when 

a tool is invoked which requires^ ,at dialog to set the 
'20 attributes of an instance of an Act iVe Object being placed 

on a Sheet by a user. The dialog ob^^cts are the objects 
! which actually embody the dialog boxes. The dialog objects 
y- contain text attributes the define th^ user^s options and 

associated operations or commands which- the user can invoke, 
25 e.g., graphically by clicdcing on an iddn representing that 
V operation, to change the properties or attributes of the . 

Active Object to which the dialog box is associated. 

The Active Objects such as those shown at 66 consist of 

labels, quotes, tickers, buttons, graphs etc. label objects 
30 are "active" even though they are text i>ecau8e they can, for 

example, be changed as part of a script of commands which 

are executed as a result of an aleunn condition. 

All the objects on the right side of the line 78 are 

stored in memory using the same structiure as any Active 
35 Object with properties emd associated operations. Some 

properties or operations may be nullities however so that 

the same structure can be used for all types of objects to 
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the right of line 80. 

A tools manager 78 manages a plurality of tools objects 
shown generally at 80. The tbols manager 78 handles the 
user input events which are associated with selection of the 
5 class of the neact type of Active Object to be created. It 
is also used to edit the existing Active Objects. The tools 
objects have associated Display Objects which invoke the 
display/windows system through the applications int:erf ace 82 
to render the icons which represMit each tool. In the 
10 preferred embodiment, the XWinclow system is used to render 
the icons which represent each ^ tool. Each tool object has 
operations associated therewith which implement the 
operations defined above in the descriptions of the tools. 
The XWindow system is avail|j3le ' commercially ^f rom the 
15 XWindow consortium of vmivefsities headed by MIT. It is 
also available through most workstation vendors subh eis Sun 
Microsystems. In other «nbodiments other window systems 
such as Microsoft Windows 3.bfpr the Macintosh toolbox in 
• the Macintosh operating system -may also be used, or a screen 
20 rendering system can be prograi^ed in from scratch. 

A global event dispatcher 84 receives event iriiormat ion 
such as ^eal time data updates^from subscription^ and user 
\ input eventi and dispatches l^e data to the apprbpriate 
object or manager or other portion of the system ' to cause 
25 appropriate processing. 

A script " pTO " 86 interprets the commands of 

scripts entered by a user defining the desired processing to 
be performed in the case where an Event Triggering that 
script has occurred. Such an e^vent could be the activation 
30 of a button or a real time data update^ which exceeds an 
alarm limit progr^oomed by the user. Basically , the script 
processor bemdles requests to process scripts generated by 
the instances of the Active Objects programmed onto the 
various Sheets by the user. | 
35 Program systems according to the teachings of the 

invention operate in an "environment" comprised of various 
other support processes (programs in execution on the host 
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computer) • The environment for a system according to the 
teachings of the invention is shown below the line 88. A 
high end network interface 90 receives requests for data 
from the system and communicates on the network (not shown) 
5 to obtain the requested data. In the preferred embodiment, 
the network interface is the TIB^ network communication 
software commercially available from Teknekron Software 
Systems in Palo Alto, California, but other network 
commvmication software may also be used./^ For example, the 
la IBM Datatrade^ system, DEC'S DECTrade^ system or other high 
level network interfaces developed in the future. The TIB 
softweure automatically maps subscription^ requests oh 
particular subjects, e*g., IBM equity /prices, into the 
: appropriate network addresses for the appropriate service 
15 and server that provides this information and selects cuid 
^carries out the appropriate service discipline and network 
protocols to communicate with the selected server over the 
.^particular network LAN/WAN system to whiqh the host running. 
. '^the system according to the invention is ; connected. 
20 ^ An operating system 92 is also part t>f the environment 
* ^'and carries out host traffic direction euifif-computer resource'^; 
: management duties necessary to support the system according 
%a the teachings of the invention. ' ■ |^ 

A file application programmers interface and file 
25 management process 94 is- also part of the environment and 
typically runs on a vf ile serv^, . . although in some 
embodiments, it may be pairt of the operating system. 

Finally, the environment includes the display/window 
systems application programmer's interface for screen 
30 rendering. The preferred embodiment of a system according to 
the teachings of the invention utilizes the commercially 
available XWindow screen rendering system. This system can 
receive commands to draw various objects such as line, 
point, box or other primitives and text, font and color 
35 codes etc. from an application program and then render the 
screen accordingly. Any known screen rendering system can be 
used in other embodiments, or the screen rendering function 
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can be prograsimed as part of the program system according to 
the teachings of the invention. 

Referring to Figure 7, the^e is shovn a diagram of the 
parts of an Active Object. An instance of an Active Object 
5 100 contains a data object 102^ a Style Map 104, a Display 
Object 106, one or more Event Triggers shovn generally at 
108 and one or more Event Scripts of commeuids to be 
performed sequentially if an Event Trigger condition occurs. 
These Event Scripts are shown generally at 110. The Active 
10 Object 100 includes a local event dispatcher which 
dispatches events, e.g., user commands, to the various 
Active Object co]q>onents for processing. For exampld, data 
updates from a network or dat^ase are dispatched to the 
Data Object 102, and "display^ frame" or display related 

15 events are dispatched to the Display Object 106. . Events 
handled by the local dispatcher can be inteimally generated, 
such as a "cdiange notification" event fjrom the Data Object, 
which is dispatched to the display Object so that the 
displayed representation can b^ updated. 

20 The Data Object contains tte internal representation of 

the data being manipulated fey the Active Object, f.e., a 
full listing of all the data -which is available sOJout a 
psirticular ^subject, only some^cMt which xioes the user) desire^ 
to view. For example, typically a quote object will vhave a 

25 Data Object with a leurge number of fields of data about a 
particuleu: company and the trading activity in that 
company's stock. 

The Style Map 104 contains a human readable 
specification defined by the user via selections from a 

30 dialog box ^ich popped up when the instance of the quote 
Active Object was created ^rtxich specify which of the data 
fields in the Data Object to display in a display frame or 
box shown on the display to represent the Active Object €md 
where to display the selected fields in the display frame. 

35 The Style Map also contains data which specifies certain 
display characteristics such as what color to display the 
object when the price is going up and what color when the 
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price is going down. The Style Hap is simply a 
specification. It does not do any of the actual work of 
rendering the Active Object instance or screening €md 
selecting data from the Data Object to be displayed. 
5 The Active Object 100 tells the Display Object 106 what 
Style Map to use. Then a style processor (not shown) in 25 
the Display Object does the work bf extracting the proper 
data from the Data Object £md sending the proper commamds to 
the screen rendering system to display the desired data in 
10 the user selected format and sty lei The Display Object 106 
encapsulates the data and operations required to display the 
data object in the "style** requested by the user. That is, 
the Display Object contains the internal representation of 
the actual data to be displayed for this Active Object in 
15 the location on the current Sheet specif ied by the user and 
a style processor. This internal representation is sent to 
the screen rendering system by the style processor to 
actually draw the display seen by the user. The style 
processor is actually implementeoi in a librcury and the 
20 Display Object 106 contains a pointer to this library and 
receives a pointer to the style Wp 104 such that the Data 
Object can be processed by the ^istyle processor library 
programs in 5 accoi^dance with thevltyle inap. 

The Event Trigger is a spedification of conditions 
25 under ^ich the user wishes to do ; extra processing on the 
Active Object. For example, the user can set alarm limits 
such as a certain price or trading volume for a particular 
quote Active Object, and when a real time data update 
indicate that the limit has been exceeded, an alarm 
30 condition exits to transfer the Active Object from the 
normal update state to the alert state. The Event Script of 
commands to execute upon occurrence of the specified alarm 
condition is specified in the Event Script specifications 
shown generally at 110. The things that can be scripted to 
35 happen upon occurrence of an alarm condition are limited 
only by the imagination of the user. Minimally, the script 
may specify an audible beep and/or a change in color of an 
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Active Object. More exotic scripts may issue commands on 
the network to start €m6ther . process running to dial a 
beeper, issue a sell order, i^sue a buy order, etc. Other 
scripts may publish some or all the data on one or more 
5 sheets of an active document j on the network, etc. The 
commands in the scripting language generally include all the 
commands understood by the script processor as well as 
commands defined by the user and can, in some embodiments, 
include commeuids to the operating system, the high level 
id network interface or other processes running oh the network. 
Generally the commands understood by the script processor 
will include the name of the oi>ject, the deisired operation 
and an argument, i.e., what value to set etc. 

The Active Object 100 also has associatied operations 
15 such as "move yourself "change the data using the real 
time network data update or a database update"; etc. Most 
operations are done by the local dispatcher. For example, 
data update events cause the 'local dispatcher to send the 
data to the Data Object 102. { Programs according to the 
20 teachings of the invention ar^ written for "event driven" 
processing style. An'"event^ as that term Is used here can 
mean a user caused event such as an input from' the keyboard, 
pointiiig device or other iiiput device or f it could be 
generated by the program itself, the network interface, or 
25 any other process in the environment or elsewhere on the 
network. The event dispatchers in the system match each 
event with some operation to call. The Active Objects have 
their own event dispatchers and there is a global event 
dispatcher which deals with input events from the network, 
30 the input devices, the operating system or a database which 
is used to store pricing information so that when a 
subscription is entered, the user may get the most recent 
data immediately and does not have to wait for the next 
update. 

35 Referring to Figure 8, there is shown a flow chart of 

the processing performed by the style processor for each 
Active Object upon the occurrence of a data update event. 
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A data update events represented at 112 causes the style 
processor in the Display Object 106 in step 114 to extract 
the values from the user specified fields from Data Object 
102. The extracted values are then stored in step 116 in; 
5 the Display Object in accordance with the specifications set 
by the user in the Style Map 104. The value of the data 
fields are then compared to any event trigger specifications 
set by the user and stored in ^the Event Trigger 
specification 108. step lis represents the process of 
10 making this comparison and computing any special effects 
specified in the Style Hap such as color changes, blinking 
etc. Step 118 may result in an update 1:6 the Display Object 
106 if any special effects are triggered. step 120 
represents the process of notifying the parent Active Object 
15 to send the appropriate commsmds to the screen rendering 
system to render the Display Object 106 in the preferred 
embodiment. In other embodiments, the style processor 
itself can send the commands to the scr'een rendering system. 
Referring to Figiire 9, there is shown a diagram of the 
20 event architecture of a program according to the teachings 
of the invention. At the left^are shownMsymbols for some of 
the input event generators. User events can be generated 
using a voice processor 124, a keyboaif<i ;i26, a mouse 128, or 
a touchscreen 130 or any other user manipulated device. 
25 Other input events can originate f rom^ the network 32, a 
file/database 132 or from the operating system 134; The 
file/database stores real time data as it comes in from the 
network so that users requesting a price etc. can 
immediately have access to the latest information and need 
30 not wait for the next update of the requested information. 
An event originating from the network or the dat€a>ase is 
usually the data returned after a request generated by the 
creation of an Active Object such as a quote, ticker, graph 
etc. 

35 A global dispatcher 136 receives the event and 

determines which object in the system it pertains to. The 
dispatcher then makes a call to the appropriate operation of 
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the appropriate object to process the event as symbolized by 
the lines of event flow 138. 

After the environment is initialized, the global 
dispatcher 136 has control of ttie system. It then waits for 
5 an event and processes each ■■ event appropriately. For 
example, a mouse event in the form of a click on a frame 
object icon such as a window meaning move this window to the 
top of the stack will be dispa^iched to the frame object 52 
by calling the appropriate operation to move this window to 
10 the top of the stack. A mouse click on a menu bear option as 
shown at 12 in Figure 1 would be dispatched to the menu 
manager 54 as a call to the operation to dislplay the 
appropriate pop-up menu for th^ suboptions of the selected 
menu option. 

15 Typically, the global dispatcher 136 will dispatch an 

event to the dialogue manageress when the user takes an 
input action to create an Active Object which requires a 
dialogue box* A typical segueiice would be for the user to 
click the mouse on a tool to create 2m instance of am 
20 object. This event would be dispatc&e^ to the tool^^ managier 
78 which woiiid^ select the * aM>^oi^^^ tdol 
objects 80. Th^ user would theS move the mouse to where the 
instance of thxs class of bbjelt is to be displayed. " This 
event would be dispatched to the appropriate tool object 
25 which would then create an instance of that type 6t Active 
Object at the desired location. A display object 
representing that object is created and commamds are sent to 
the rendering system to draw the display object. The user 
then clicks the mouse on this displayed Active Object and 
30 the appropriate one of the dial'bgue boxes 60 pops up. The 
user may then select the veurious options in the dialogue box 
to invoke operations to set up the properties of the Active 
Object represented by one of th^ Active Object boxes at 66. 
After the user is done specifying the Active Object desired, 
35 the dialogue box performs an update operation when the save 
button is "pushed" to set the properties of the Active 
Object as specified by the user. 
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A network event is dispatched by the global dispatcher 
to a network data dispatcher 150. This dispatcher examines 
the type of data it is and sends it to the appropriate 
Active Object. The network data dispatcher can **fan** the 
5 data out to more than one Active Object if more than one 
Active Object exists with an interest in; this type of data* 
A file/database data dispatcher 152 does the same thing as 
the network data dispatcher except it, does it for data 
events originating from the file/database 132 after read I/O 
10 operation. 

Some events can originate within emd are locally 
: dispatched from the Active Objects themselves or from the 
menu objects. For example, the user may click on a font 
change option from one of the menu objects 56, and this 
15 event will be dispatched as an update to the style map of 
the currently selected Active Object. Likewise, a data: 
update to an Active Object may cause ,the value of some 
. variable to exceed the alarm limits for ^at variable set by 
the user.. In such a case, the local dispatcher of the 
,2Q Jlctlye O^jec^ makin? J*^e .1^:ansit:io|x,^.^^ t|ie,^-alert . state 
^ will Invoke a script processor 15^. aji^d send the use^, 
: specified script for the appropriate .,^Iarm event to the 
^ script processor. The sjcript processor jthen processes the; 

script to carry out the commemds specified in the script in' 
25 the order specified in the script. If one of the commemds 
in the script is to change a color or a font, the script 
processor will call the style map of the Active Object 
specified in the script (it may be different than the Active 
Object which triggered the script processing) and update the * 
30 style map of that^Active Object. If the script calls for 
publishing some data, the style processfpr calls the high 
level network interface 90, invokes a publish function and 
sends the appropriate data to be published on the network. 
Likewise, if the script calls for sending; data to a database 
35 156, this also can be done. The script! may also call for 
invoking some function of the operating system through an 
operating system call 158, and can invoke other applications 
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160 irunning in the same environment. Further, the script 
processor may also cause; the other application to perform 
some function and may even; cauise the other application to 
access the network through the network interface 162 of the 
5 other application to either send or receive some data 
specified by the script. 

Of course the Active Oh^jects all may dispatch rendering 
commands to the display rendering software interface to 
render their respective display objects. 

10 The script processor 154 may also be called by the menu 

objects 56 or the dialogue boxes 60. This allows the; user 
to directly cause scripts previously defined by that user or 
some other user to be run by selection of a m^u or dialogue 
box option to that effect and designating the desired script 

15 to run. 

The objects of the Active Document are. arranged in a 
hierarchy, £uid escalation of events within the hiereurchy is 
allowed. For example, the line 164 represents the fact that 
the frame object manages the menu mcuiager, and the line 166 

20 rej^resents the f act - that thfe- menur manager manageis the menu 
objects. A& example of an^scalation of an /event would be 
where the user selects the dlose option to close the active 
doeunt^t* 'This event wou4d first be escalated from thB 
appropriate menu object to the menu manager 54 to make the 

25 menu disappear and then wbuld be escailated to the frame 
object 52 because the menu manager does not have an 
operation associated with it to close an active document, 
only the frame object has that capability. 

similar hierarchy exists for the frame object, dialogue 

30 manager and dialogue boxes. A similar hieraorchy exists 
within the Active Objects themselves although this is not 
shown. The Active Objects are also msmaged by sheet objects 
which are not shown in Figure 9 but which can be seen in 
Figure 6. The sheet objects are managed by the frame 

35 object. An example of escalation of an event in this 
hierarchy is when the user invokes a "delete yourself" 
command to delete an Active Object. The will cause an event 
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escalation from the selected Active Object to the 
coxxesponding sheet object on which the Active Object 
appeared to cause the sheet object to delete the Active 
Object from its list of current Active Objects. 
5 Simultaneous event processing is allowed. For example, 

if the user is dragging an Active Object to another location 
with the mouse, a series of mouse move events are occurring 
which are being dispatched to the frame object 52 which 
contains the code for processing mouse moves. These events 
10 result in event dispatches to the selected Active Object to 
tell it to move itself . Simultaneously, a network update 
event can come in to cause a vali^ in the Active Object to 
be cheuiged and this may cause an alarm and the associated 
script processing. 
15 In alternative embodiment^, the tools may be 

represented as menu selections or simply be invoked by 
typing or speaking their names rather than through graphic 
selection of icons with a mouse, touchscreen, trackball or 
through keyboard navigation with the arrow or tab keys. In 
20 some embodiments, a map-ljJce^:CO(0^ be_ 
used, and the user could select tools, menu options or 
Active Objects by speaking their coordinates. Their must be 
one input deyice however, although it may be connected to 
the host running the program accoirding to the teachings of 
25 the invention through the network or through another 
application with an intexrproces& communication mechanism 
such as shared memory,^ Unix pipes, etc. 

In some embodiments, the program itself may specify the 
placement of Active Objects and automatically fit them 
30 together after the user specif ies what he or she wants in 
the active document. 

Button objects provide great flexibility. A button 
object can be scripted to pop up on a user written help 
screen, make another Active Object appear or disappear, or 
35 do any other commands or seguencet of commands within the 
scripting language. 

The menu bar 12 in Figure 1 includes a hide/show toggle 
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option wherein Active Objects can be hidden, i.e., not 
displayed, although an internal representation of the 
display object is maintained so that at any time, the object 
may be displayed once again. This is especially helpful for 
5 user defined help screens which the user does not want 
visible at all times. 

MartetSheet™ APPLZCATIOH 

MarketSheet™ is a Teknekron,^ Software Systems application 
that allows traders, brokers i;. and others to customize the 
10 presentation euid monitoring of maurket information. An 
"vobject oriented" approach provides a state ..of the art user 
interface and display environment; use^s and system 
administrators define customized mairket data information 
pages or "sheets." A sheet is an aarbitraory arrsmgement of 
15 objects, each of which displays an item or group of related 
items in a pre-defined way. There are standard sheets which 
come with the product, shared sheets use^d throughout a 
depsurbment or entire firm, and specialized sheets used by an 
' individual or smaai group. ^ ^vJtorkjBtSheet"*^)^^ user 
20 complete flexibility to pi^gfanize,. format, and display 
inf ormation as the user needs^at. 

HarketSheet™ receive? . |its market the 
Teknekron Information Bus™ iTIB^) coniponent, a powerful 
suite of communication protoippls that separate information 
25 sources, like HarketFeed 2, Ticker III, or Telerate TDPP 
from information constuners, like HarketSheet™ or Teknekron ^s 
RealTime Spreadsheet. This means the user can add market 
data feeds without obsoleting your applications and the user 
cam add applications without changing feeds. 
30 The MarketSheet*" application is a member of the 

Teknekron Trader Workstation System family of applications. 
As such, it employs a niunber of concepts which are described 
in the Trader Workstation Introduction manual. Thus it is 
pairticularly important to readi that manual first. 
35 The followjjig sections are organized as follows: An 

introduction introduces the features and priioary objects of 
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HaurlcetSheef 



Then a Tutorial explains how to use 



MarketSheet™, covering many of the basic operations. 
Finally, a Reference section describes the menus, objects, 
and scripts in detail. Most of this detail is not needed 
5 for a first reading but will be useful after becoming 
familiar with the progreua. 

This version of the Market Sheet™ program corresponds to 
Versions 2.1 and 2.2 of the product. These versions differ 
only in which feeds are supported. Version 2.1 does not 
10 support MarketFeed 2 in order to load faster and operate 
with less memory. No differences are seen by the users. 

AZMTRODUCTIOH 

Paaturas 

Features of the HarketSheet"" application include: 
15 • Display 



The display consists of objects on sheets. The user 



20 




25 



MarketSheet™ uses a pull-down menu system. The Menu 
Bar is always displayed across the top of the window, 
displaying the names of the available menus. Clicking 
on a menu title causes the menu to appear below the 
bar. Selections from these menus are tbq. "commands'* 
that drive NarketSheet™. 



Dialog Boxes 



30 



Pop-up dialog boxes are uised to input characteristics 
associated with each object or sheet, such as meurket 
symbol, exchange, graph axis limits, etc. Dialog boxes 
are also used to specify more detail in many of the 
commands. 



35 • 



Layout 
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There axB a number of helpful facilities for aunranging 
items on a sheets such as user-specifiable grids for 
alignment, and coxnmcinds to bring overlapped objects to 
the front or to the bade. Objects can be aligned to 
5 the grid either on creation or at any later time. The 

grid can be adjusted throizgh the sheet edit dialog box, 
and the grid size is maintained separately for each 
sheet. Layout commands are consistent among the 
different tools* : 
10 • Scripts 

The user can define a sequence of actions to be caEried 
out ^en a button is pressed or a price update occurs. 
These actions are es^ressed in a macro language called 
MearketScript. This facility greatly increase the 
.15 flexibility and generality of the program. 

• Alerts 

The system monitors for alerts (such as upper and Iowa: 
limits) in each quote or ^ynaioic graph. The alerts can 
execute scripts in order ^ to change the appeareuice of 

n 20 monitor items on the sa;^^.. The scripts can even run 

other programs, such as ^a»r;program to play a sound file 

4- . for audip alerts, or to l^g^ the alert in a file. 

.f . • Sisplay .s^tyles .. J- • 4 

Each Quote and Ticker object uses a display st^le to 
25 format its output. These flisplay styles indicate which 

fields to shov (symbol, price, bid, ask, etc.), how 
wide to make each field, ^and what colors to use* The 
flexibility of the style facility allows formats t o 
resemble the Quotron screen displays, or the Equity 2 
30 terminal. The user cannot edit the styles, but a 

number of standcurd formats are provided, and the 
MarketSheet™ AdmdLnistrator^s Manual describes how to 
edit the s^les and add new ones. 
• Files 

35 The user can create multiple IburketSheet™ files that 

can be saved and reopened, much like the files in thB 
RealTijne Spreadsheet. Each file can contain many 
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sheets. 

OBJECTS AND TOOLS 

The application displays "sheets" or market 
information. Users can create any number of sheets, which 
5 are then organized into ah index for each access. Each 
sheet displays "objects" created by tools in the "toolbox." 
Available types of objects include: 

• Label 

Labels provide status text to enhance' or annotate the 
10 display, such as "Market Summary" placed at the top of 

a sheet. ? 

• Quote 

Quotes display securities prices and other TIB 
subjects in niimeric format, with prices changing in 

15 real-time. Data can be displayed from any 0 

element ized feed (such as MarketFeed 2), from 
shredded page-based services (such as/^ Telerate or 
Reuters) , or from any TIB subject pviblished on the 
network (such as a calculation published from the 

20 RealTime spreadsheet or a C program) ; r 

• Dynakic Graph 

Dynamic graphs chart Securities pric^ and other TIB 
subjects in real-time. Multiple siibjects can be 
included in a graph euid sixqdle arithmeitic operations 
25 can be performed on the axes, such as .^spreads. Graphs 

can also be merged, meaning that two prices cem be 
shown against one time axis. 

• Ticker 

Tickers display a list of securities prices and other 
30 TIB Siibjects that scroll as the subjects change in 

real-time. The user can specify the securities anA 
exchanges to be included in the ticker and set volume 
thresholds. 

• Page Fragments 

35 Page Fragments are "cut-smd-paste" sections from page- 

based data sources (such as Telerate TDPF or Reuters 
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RDCDF) and displayed as o]>jects in MaurketSheet^. The 
fragments update in reai-tine. 

i 

• BttttOBS 

Buttons are triggers for< scripts which are carried out 
5 When clicked. These scripts are e3cpressed in the 

IferketScaript^ language. ' In most cases, these actions 
are similar to those inaccessible through the menus, 
but these triggers can be placed on the sheets 
themselves. For instanc4, the user can create a button 
10 which will bring up a psurticular sheet when clicked on. 

This allows the creation of "hypertext links" between 
related information, sucti as a security and its options 
pricdLng* Available tools include: 

• arid 

15 When this tool is active, all creation, movement, and 

resizing of objects will be adjusted to match the 
current sheet grid settings. 

• Selection 

This tool is used to select one or more objiects for 
20 editing, or to move or resize the objects. 

• Duplicate 

This tool is used to mkke copies of an existing object. 
The copies are. arranged in a grid. This tool is very 
useful for creating monitor lists or grids. 

25 TDTOXIZAL 

gemnq Stiffted With Hay|^etBhoet« 

This section discussed MarketSheet™ informally, 

introducing concepts in the sequence the user might 

encounter when e3q>erimenting with the program on your own 

30 workstation. The Reference section is more structured and 

J, 

covers memy of the same topicis in more detail. 
Basic Display 

The MaorketSheet™* display shows a rectangular region, 
called a Sheet , in the application window, on which any 
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number of objects may be placed. 
Sheet Name 

Figure 1 shows a sample MarketSheet™ display. At the 
top left of the screen is the Title Bar. Below it is a line 
5 containing the Sheet Name indicator, the Index Position 
indicator and the Menu Bar. The Sheet Name indicator is 
used to show the name of ; the Sheet currently being 
displayed. It can also be usQd for quick access to sheet 
attributes Double-clicking pit the Sheet Name indicator 
10 opens the Sheet Editor dialog box. 

Besides the Name, the attributes of a sheet are the 
bacOcground color, the grid size, how the sheet should be 
changed when the application is resized, and whether the 
grid should be shown. These characteristics can be modified 
15 by the user. 
Index Position 

Next to the Sheet Name indicator is the Index Position 
indicator. This indicates how many sheets are in the 
current file and which sheet number is showing. It can also 
20 be sued for quick access to index information. A 

double click on the Index Pdsition brings up the Index 
dialog box, which displays a^ list of the sheets in your 
MarlcetSheet^ file. 
Menu Bar . 

25 To the right of the Index Position indicator is the 

Menu SS3^ shown in Figure 11. The menus pull-down by 
pressing and holding down on the menu choice using the left 
Mouse button. The menus are the main way of carrying out 
commands in the system. Commands provided in the menus 

30 support changing and editing the contents of the sheets. 

Pressing the left button while you're pointing to a 
menu title causes the title to be highlighted and the menu 
to appear. While holding the button down, drag the pointer 
down through the entries of the menu. As the user drags 

35 through a menu, each usable command is highlighted in turn. 
If the user changes your mind about choosing a command, move 
the pointer off the menu and release the mouse button. 
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Nothing is chosen unless the user releases the mouse button 
while one of the commands is highlighted. 

Some menu commands will be shown in gray rather than 
black. These commands are not available right now. For 
5 instance, if there is only one sheet, the command to move to 
the next sheet is not available. Some menu commands are 
shown with three dots after th^ir name. These are commands 
which will bring up a dialog box for further specification 
of information; For instsmcfe; 1^ Create; command under the 

10 sheet menu brings up a dialog box so that the user can enter 
the name of the sheet to be created. 

Many menu items have a keyboard shortcut which is a way 
of selecting them without using the mouse. The more 
commonly used commands have a diamond and . a letter to their 

15 right. This indicates that the^ command can also be selected 
by holding down the diamond key (to the left and right of 
the space bar) , and pressing the specified letter. Note 
that the title of the menu contj^ining the command will flash 
when the commapid is selected^ but the ' menu will not be 

20 shown. 

Qbjeots ' '-^^ 

The sheet in Figure 1 cbiltains the following objects: 
At the top is a label whicJ^ displays ithe text "Market 
summary." Belcw it is a short %uote showing the last trade 

25 in XYZ. Below that are a cnraph (not shown in full detail) 
and a fragment of the Reuters n$£D page. Near the bottom of 
the sheet are a button and a ticker. 

DIM.06 BOXES 

Dialog boxes are used in several places where 
30 information must be specified about an object or an 
operation. For instance, double-clicking on an object brings 
up a dialog box in which its characteristics sure shown. A 
typical dialog box contains the following kinds of items: 

• labels and grouping boxes - 
35 • text entry areas 

• buttons 
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• lists 

In the example of Figxire 12, "Name" is a leO^el, and to 
its right is a text entry area. To change or enter 
information in a data entry field, click the left mouse 
5 button within the field. A small typing cursor appears at 
the point of text insertion. Use the Bacdc Space key to 
delete old text. Type in the next text. The user can also 
select the text to be replaced by dragging through the 
characters with the mouse. . The characters dragged through 
10 will be highlighted, i.e., shown in white on black. The 
next character typed will replace the selected text. 

To select an option via a selection button, click the 
left mouse button within the square box next to the name of 
the option. Some options are "toggles" which turn on and 
15 off individually each time the user cldcks them. Others are 
"radio buttons," a list of altematiyes of which only one 
will be active at any time. 

To use a list, clock with the mouse on an entry of the 
list. These are typically used for lists of color names or 
20 sheet names. The Sferoll Bar to -t^e right of the list 
indicates what poirtion of the list is visible, : if not all 
the entries are showing. Click on the up or down arrows of 
the scroll bar to see more items. in|ie center part of the 
scroll bar will Indicate what portio^; of the full list is 
25 being shown. Clicking and dragging the mouse on it will 
enable quick scrolling to the beginnii|ig or end of the list. 

One item on the dialog box has title Input Focus at any 
time. This concept is similar to how the Control Panel 
selects which application window has the input focus. The 
30 focus is indicated by drawing a black rectangle around the 
item. For instance, when si dialog box first appeaurs, the 
item in the upper left will have the focus. To shift the 
focus, use the arrow keys to move it left, right, up, or 
down. In addition, the Tab key can be used to move to the 
35 next item, the Shift-Tab key can bemused to move to the 
previous item, and the Keypad Home key can be used to move 
to the item in the upper left. When a button is traversed 
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to, it may be "clicked on" by typing the space bar. 

When a teact entry field is traversed to, its entire 
contents are highlighted so that the user Ccm easily enter 
another string. In order to simply edit the existing text, 
5 click in the text to specify the insertion point* 
Alternately, the following* keyboard equivalents are 
available for setting and movihg the insertion point through 
keyboard commands: 

Control-P moves thel^ insertion point forward 

10 Control-B moves the v insertion point backward 

Control-A moves the^ insertion point to the 

begiiming|^ 

Control-E moves the ^ insertion point to the end 

tr ■ 

To conclude a dialog b^X' operation, click the left 
15 mouse button on an action button. These €ure command names 
suinrounded by a rounded border and, on a color monitor, 
shaded in color. Host dialog boxes have "OK" ^or "Cancel" 
buttons to accept or reject the dialog box action and exit 
the dialog box. Dialog boxes' fiii^y also be exited^. by pressing 
20 the Return key which is equivalent to OK, or by pressing the 
Escape key which is equivalent: to Camcel. 

XANIPULATZNO SHEETS 

A MarketSheet™ file is orgwized into a list of sheets, 
or pages, of whi^ only one sl^ietet is shown at a time. Hence, 

25 the most common operations are to change which sheet is 
showing. Operations to show '^e First, Previous, N^ct, and 
Last sheets sure provided in | the Sheet menu as shown in 
Figure 13, below. These will navigate through the ordered 
set of sheets in the system, i 

30 An alternative way of navigating to other sheets is to 

use the Page UP and Page Down keys. On the Sun keyboeord, 
these aure R9 and Rl, corresponding to the placement of the 
Page Up and Page Down keys on the keypad of an IBM PC. 

Yet emother way to change sheets is to display the 

35 Index dialog box, using the Index operation on the Sheet 
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menu. This is shown in Figure 14, below. The dialog box 
contains a list which holds the names of all of the sheets. 

To display a sheet, select it and then click on OK, or 
as a shortcut, double click on its Index entry. The scroll 
5 bars may be used if there are more sheets than will fit on 
the display. The buttons to the left of the list are used 
to change the ordering of the sheet in the list of sheets. 

CRSMFZHO Xm DBLBTZNO BBEBTB 

Besides moving around to the different sheets, the user 
10 can also create, delete, rename, and change the order of the 
sheets. The Sheet Create menu command |is used to add a 
blank sheets A dialog box will appear Ih which the sheet 
name may be entered. 

The name of the new sheet def aults jto "No Name," and 
15 the new sheet will be placed after the current sheet in the 
index. Note that it is allowable for more thsm one sheet to 
have the same name. 

To change sheet characteristics such as the name, the 
- f background color, or the grid sizes (to b^ explained below) ; 
20 use the Sheet Edit operation or double-clicdc on the Sheet 
Name indicator. Complete the dialog entity by clicking oh 
4 the GK buttonw ' K i 

^ The Sheet Delete menu command is used to delete the 

current sheet. A dialog box will appeak", indicating the 
25 name of the current sheet and reguiriiig that the user 
confirm the deletion. Note that irtien there is only one 
sheet, it may not be deleted. 

The Sheet Index menu command is used to change the 
current sheet, as seen previously, and it can also be used 
30 to change the order of the sheets. BringSup the dialog box 
and then click on a sheet name which is not the top one. 
eliding on the button marked "Top" will then move that 
sheet to the top of the list. Click on "OK," and the 
selected sheet will be moved to the first position. There 
35 are also buttons to move a selected sheet forward one 
position, backward one position, or to the end, and to 
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create, delete, and rename sheets while the index dialog is 
active. 

M&IVZPOL&TZMG OBJECTS 
Toolbox 

5 The Toolbox is a vertically arranged set of icons or 

buttons along the left side of the display sheet as shown in 
Figure 1. It is initially not j shown. Using the Shoy tool- 
box coBffliand in the Edit menu will cause it to appear on the 
left side of the Display,. ? 

10 The Toolbox contains an icon to indicate whether the 

Grid tool is active, then a gap, then an icon to represent 
the fielection tool (or arrow) , then an icon to represent the 
Duplication tool, and then an icon for each of the ava|,lable 
object types. Only one of the^^^ools can be active at any 

15 time. It is shown in reverse video. The Grid tooij. is a 
toggle, either on or off. 

mie Toolbbk is used to sdlect the next object to be 
created. After picking a tool j[such as a Quote), click and 
drag to draw a rectangle on the tnirrent sheet. The selected 

20 type of object will be created, and the Toolbox will 
reselect the Selection or toolr^r 

If the Grid tool icon is the corners of thiei drawn 

rectangle will automatically be ~^ad justed to the grid isizing 
for the sheet, whether or not .the grid is actually I being 

25 shown. This is a useful page layout feature when creating 
an array or similar items on a sheet. 

SEZiECTZHG OBJECTS 

Editing operations provided by the menu system will 
operate pn selected object f si on the current sheet. Selected 

30 objects are indicated by a "picture frame corners" around 
the object, as shown in Figure 16. To select an object, 
single click on the object with fthe mouse. A way to select 
more than one object at a time is to draw a large rectangle 
(using the Select tool) suround the desired objects, as shown 

35 in Figure 17. 
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Holding down the Shift key acts as an "extend 
selection" feature similar to many programs for the Apple 
Macintosh, allowing the user to select and highlight more 
than one object, by clicking on each one of them. If the 
5 user clicks on a selected object, it is unselected. 

If the user draws the selection rectangle with the 
Shift key held down, any objects in the selection rectangle 
will be toggled , reversing the selection state of all 
affected objects. The user can unselect all objects by 
10 clicking the left mouse button on an empty area of the 
sheet. 

Another way to select objects is to select all of: them, 
by using the Select All command -in the Edit menu. 

USIKG KEYBOARD TRAVERSAL 

15 The keyboard traversal facility allows the user to 

change which object is receiving keyboard input, much like 
the Control Panel function keys eure used to change which 
application receives the keyboard input. This is al^o the 
same facility which is used f or liavigation in dialog boxes. 

20 Not all objects can accept the keyboeurd traversal; currently 
only the Quote, Page Fragment, sbrid Button objects do^ 

The object which has the tz|tversal focus will be shown 
with highlighting market along the sides, not the comers. 
This Is shown in Figure 18. " Note that selection and 

25 traversal are two distinct operations and are indicated by 
two distinct highlights. When an object is both selected 
and traversed to, the highlights will m^ge to form a 
coiQ>lete border. 

Use the arrow keys to navigate in direction such as up, 

30 down, left and right. The Tab key will move to the next 
item, and the Shift-Tab will move to the previous item. The 
tabbing sequence is the same as the stacking order, which 
defaults to the order in which the items were made. This 
can be altered using editing operations described below. 

35 When there are more than one selected object, one is 

marked as the Traversal object, meaning that keybo2a:d input 



wo 92/12488 



PCr/US91/09811 



- 56 - 

will be sent to it* This facility is mostly used for quick 
editing of the symbols in Quote objects, or the current page 
shown in a Page Fragment, which^ are explained in more detail 
below. 

5 DUPLICATING OBJECTS 

The Du plicate tool may be used to msdce copies of 
objects on a sheet, which will be arranged into a grid of 
copies having the same size as ;the original. 

^ To use the Duplicate tool/ first creajte an object, and 

10 set up its cheuracteristics, such as size, colors, font, and 
other attributes. Place the object in the upper left of the 
region to be filled with copies. Then click on the 
Duplicate tool icon in the toolbox. Now click with the left 
^button on the object to be duplicated, and ^ag right and/or 

15 down to define the region to be filled. As the mouse is 

dragged, the outlines of the copies to be created will be 

shown. When the region is compete, release the mouse, and 

the copies will be made. The ^ Selection tool will be made 

■ ^ ■ . ' • 

active again so that the user can operate on the copies. 

20 Note that - the Duplicate ^pol cannot' - be used to make 

copies of Graph objects, due to their composite structure. 

EDIT MBHU OPERAXIOH8 

Once an object is selected, the user can perform 
editing operations using commands from the Edit Menu . 
25 • Cut CDeletet the eblect 

• gront brings the obi act to the front of the 
overlap list 

• Back sends the object to the back of the overlap 
list 

30 Since objects can overlap each other, the user may want 

to bring one object to the foreground, or push one object to 
the background. 

Objects are normally shown, but the user can 
temporarily hide them, using the Edit Henu. 

35 • Hide the object 
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• Bhoir the Qb^^ct 

These operations are often used to create pop-up 
objects on the sheet which are not visible until the user 
shows them. In most cases, button scripts are used to 
5 automatically pop up and down the hidden objects, in order 
to display help or additional infoxmation. This is 
e3q>lained further in the Buttons section* 

To make page layout easier, the user can fit objects to 
the Grid or overlap objects as shown in Figure Id. To see 
10 the grid, use the Sheet Edit command tp bring up the Sheet 
Editor Dialog Box. Change the Grid Size by single-clicking 
anywhere in the Grid Size box. Once the user has created 
the desired grid size, click on the Draw Gridlines button 
and close the Dialog Box. The Grid lines will now be drawn 
15 on the sheet. 1 

Aligning objects will automatibally resize their 
borders to the size of one grid box, 'or multiples of the 
grid box size, if the object is large^^- When the user has 
selected the objects to be aligned, ch6bse 
20 • Align 

to resize to the grid. Selected objedbs will align to the 
grid. Other objects will not move. / 

In order to refer to specific, obj^pts or collections of 
objects in the MarketSbript* language u^ed by the scripts, 
25 objects can be given names. Note that the neune of a label, 
for instance, is different from the text shown by the label. 
Choose ' * 

• y^Mo — 

to display or change the na.e A dialog box will appear, 
30 indicating the name of the first selected object. The name 
can also be changed through this dialog box. The name 
change will apply to all of the selected objects. 

MOVE AHD RB8IZB OPERATZOKS 

Some editing operations do not require the use of the 
35 Edit Menu. The user can move or resize an object using the 
mouse to specify what the user wants to do. 
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Objects can be Moved bv Selecting them, pressing down 
• and holding the left mouse button, and then dragging the 
objects to a new location on the sheet* 

To Resize an object, press and hold the left mouse 
5 button on any one of the comers of the Selected object(s). 
Some degree of precision is required, since the mouse cursor 
must be within 2 pixels of the comer. 

Note that while moving or resizing, the mouse cursor 
will change into an arrow ^indicating the movement or 
10 direction of resizing. 

roma, coLcots, and borders 

Besides editing a selected object or group of objects, 
the user can also change their display chauracteristics. 
These display cheuracteristics ^are accessed from the Menu 

15 Bar , and include: 

Mode s changes the, highlighting mode for page fragment 
objects. This is deslbribed in more detail below. 
Font : changes the font size and style. f 
Pen: changes the color *fo!r the teact and bord^. 

20 Border : changes the width for ^the border of the ^object. 
Fill : changes the color which fills the back^ound of 

; j. the objects . . M ' ■ h 

Note that the user cannot the border 6t Button 

objects, as their border is internally to provide 

25 different shapes. 

DIALOG BOXES 

To edit the detailed characteristics of an object, such 
as to change a label^s text '- or a quote's stibscription 
information, double click on the object. A dialog box will 
30 appear showing that the object's attributes. The dialog 
boxes are different for the different types of objects, but 
all have OK, Cancel, and Revertt buttons. 

For a label, for instance,: there . is a text entry area 
for the label's text, and a set of radio buttons to ^ecify 
35 the alignment mode of thB text. 
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The specific attributes of the different classes are 
• described joore fully in the Reference section of this 
manual. 

ZHTRODDCTIOIf TO SCRIPTS 
5 The script facility in MarketSheetf is primarily for 

advanced users, so only a brief introduction will be given 
here. Scripts may be used to go to the next page, to a 
specific page, or to alter the appearance or layout of 
objects. They are composed of one or zibre actions, which 
10 are entered as a sentence. For instance, one script would 
be "Governments find sheet", which would find the sheet 
named Governments and show it on the screien. This would be 
faster than bringing up the index dialog box, searching 
! through the list, and: selecting the enti^ for Governments. 
15 Thus, scripts can be thought of as a i^cro facility for 
commonly performed functions. Scripts can chain together 
^several operations, such. as "next sheet ^ext sheet", i^ich.^ 
mould go to the next sheet, and then the^sheet after that. " 
i.: The section on scripts in- the Reference part of this^- 
20^,m2mual^ describes the available operatioii6> 

' alert facilities t, 

The dialog box for a Quote object lllows the user to ^ 
set upper and lower limits for a specified field. When its 
limits are reached, a Quote object is^^ shown in reverse 
25'' colors (i.e., its pen and fill colors are reversed). 

When a Quote reaches a limit value, it will run one 
. more scripts, which the user can enter? There are four • 
scripts associated with each quote, which are run at the 
start of an alert, the end of an alert7 during a normal 
30 update, and during an alert update. This is explained in 
more detail in the section on Quotes in the Reference Part. 

For a Graph, alerts are triggered yitien the plot line of 
the instrument moves outside the channel cheated by an upper 
or lower trend line. 
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LOADING AND SAVING SHEETS AND SHEET SETS 

Only one set of sheets (one file) is active in 
MsurketSheet^ at any time. File menu operations New, Open 
Add, Close, and Save are used to create a new sheet set, 
5 open (read) an existing one, add another file's sheets to 
the current file, close the i current one, and save the 
current one. Version shows the Version Number for Market 
Sheet. Note that while a file is open, the New and Open 
operations are disabled, and w^ile no file is open, the Save 
10 and Close operations are disabled. 

The Open and Add operations will bring up a dialog box 
which lists the files already saved in this account. To 
select one of these names, simply click on it, or type a new 
name into the text edit box and HarketSheet® will search the 
15 site-wide accounts as well. 

Note that the cxirrent file name is shown in the 
application window title bar and will also appear ' on the 
icon window title. :r 

The file name that the user types will automatically 
ib have the suffix *'.ms" added^;' to it. ^This avoids the 
possibility that the file wil£^pverwrite one of the system 
' files on the disk, which will have a different suffix. 

OH-SCREEH HELP 

There are two ways to : obtain on-screen help with 
25 MarketSheet™. The user can kelect Help from the Trader 
Workstation Tekneloron Menu and then select MarketSheet™ f rom 
the list of help subjects. Or, the user can click on the 
Help gadget in the upper right corner of the MarketSheet™ 
window frame. In either case, a HarketSheet™ Help Menu will 
30 appear listing subjects for which help is available. Some 
of these subjects invoke subsidiary help menus. Once the 
user selects an item for which help text is available a help 
window appears on the screen, overlapping other windows. It 
displays a page of text on th# chosen subject. Click the 
35 Close gadget in the upper right comer of the help window to 
erase the window and return the display to its state when 
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the user requested help- 

REFBRSNCE 
Kenus 

Figure 2 shows the basic MarketSheet^ display and the 
5 menus that the user can select from the. main menu bsur. 

Menu items shown in bold type are active in the current 
product release. The notation " — " appears on the screen as 
shown in the figure and serves as a logical sepeirator 
between related groups of menu items. Menus iihich contain 
10 the notation ••...»» as an item are lists of fonts or colors. 
What appears on your screen will be a longer, somewhat 
different list. 

Menu items that consist of a command name followed by 
display a dialog box when selected. 

15 FILE MENU 

Use the File Menu to create new collections of sheets 
("files'") , to select files, and to save change^^'the user has 
made to.-^files. File Menu commands are: i 

• Hew 

20 V The File New command creates a new fxie. Once the 

3 user has made a new file, the 1^ and Open 
commands are^ disabled until the user closes the 
file. 

• open 

25 The File Open command displays a dialog box in 

which the user enters the nsune of a previously 
created file with which the user wishes to work. 
The dialog box will contain a list of files which 
are already saved under your account. When the 

30 user accepts the dialog box, the file the user 

named will replace the currently active file. 
Once the user has opened a new file, the New and 
Open commeuids are disabled until the user closes 
the file. 

35 • Add 
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The File Add command copies the sheets from a file 
and adds them to the currently displayed file. 
The additions zure temporaury until the user saves 
the current file. Add displays a dialog box into 
which the user types the name of the source f ile« 
The dialog box will cbntain a list of files which 
are already saved under your account. Dialog box 
command Add executes the operation. Cancel exits 
the dialog box without performing m operation. 



10 • Close I 



The File Close command removes all sheets from the 
application, terminating access to the current 
file. Once the user has closed the file, the 
Close, Save, cmd Save As commemds eare disaibled 
15 until the user opens a file or create a new file. 

• save 

The File Save commands saves the current fxle. 
Changes the user has made becomes permanent. The' 
name of the file does: not change. Note that if ^ 
the Current file hasT/iiot been changed^ this item- 
is diseUbled. r 

• Save As ' . \ . 



The File Save As co^i^ind saves the current file .Mi 
It displays a dialog box into which the user' 

25 enters the name of ^the file. When the user 

creates a new file the user must save it with 
Save As in order to assign it an initial name. 
Later the user can save it again with Save, 
preserving its name. To create a new file that is 

30 similar to an old one. Open the old file, make 

your ch2uiges, and then use Save As to save tha 
new version with a new name. 
• Version 

The File Version command displays the current 
35 software version number in a dialog box. Tl^is 

information is needed when reporting a problem 
with the software. Click on OK to remove the 
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dialog box. 

EDIT MEND 

Use the Edit Menu to manipulate objects on the current 
sheet. Edit Menu operations are: 
5 • Undo 

(not iaplenented in the current release) 

• cut 

The Edit Cut coimiand deletes all currently 
selected objects from the sheet.' 

10 • Copy 

(not implemented in the current release) 

• Paste i 

(not implemented in the current release) 
Selaot All 3 

15 Selects all the objects on the current sheet. 

• Front 

The Edit Front command moves all selected objects 
to the top of the overlap stack so they become 
fully visible. Objects that overlap the selected 
20 objects will move to the back. ^ 

• Back' . 

iPxB Edit Back command, moves ail !selected objects 
to the bottom of the overlap stack so they do not 
bbscxire any other objects, objects that overlap 
25 the selected objects will move to the front. 

• Hide ^ 

The Edit Hide command makes all selected objects 
invisible on the screen. This Command is often 
combined with the Edit Show command to make 
30 objects pop up and down on the sheet. 

• Show 

The Edit Show command makes all iselected objects 
visible on the sheet. This ccnomand is often 
combined with the Edit Hide command to make 
35 objects pop up and down on the sheet. To select 

a hidden object for use in this command, us^ the 
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Select All commamd, or use the mouse to drag a 
selection rectangle 2around the space where the 
object should be, 

• Align 

5 The Edit Align command adjusts the positions of 

all selected objects to align with the current 
grid. 

• Marge ^| 

The Edit Merge command merges graphs. Select the 
10 price axes of . two ^aphs and then execute the 

Merge commemd. The first graph disappeeurs and its 
price axis is added to the second selected graph, 
creating a multiple axis graph. 

• MUM..* ' . 

15 The Edit Name. . • command is used to display or 

chemge the names of ; the selected objects. This 
allows the objects to be tagged so that they can 
be referenced in button scripts. A dialog box 
will appear, showing the name of the first 
20 selected object, ahd^^if a new^ame is entered, all 

selected objects vill be repamed. Another use of 
the Name command is^ ;to assign a name to a ticker 
, ^ so that itis selection list can be copied^ when 

defining other tidceris. 
25 • _jShow [Hide] Tools 

The Edit Show Tools command causes the toolbox to 
appear on the left side of the display area. Use the 
toolbox to create objects and to control the grid. When the 
toolbox is displayed, this commiand becomes Hide Tools. Hide 
30 Tools turn off display of the toolbox. 

SHEET MEND 

Use the Sheet Menu to create, delete, and modify sheets 
and to navigate among existing sheets. Note that it is 
allowable for more than one sheet to have the same name. 
35 This allows the "find sheet** scripting operation to navigate 
through a series of sheets. 
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• First 

The Sheet First coso&and transfer to the first 
sheet in the list of sheets in the current file. 

• Frev 

5 The Sheet Prev (Previous) command transfers to the 

previoiis sheet in the list ;of sheets in the 
current file. 

• Next 

The Sheet Next command transf eris to the next sheet 
10 in an the list of sheets in th4 current file. 

• Last 

The Sheet Last command transfers to the last page 
^ in an the list of sheets in the ciirrent file. 

• index 

15 The Sheet Index comm^d brings up the Index dialog 

box. This can be used to revieW the names of the 
sheets, to select a different :^eet, or to change 
the order of sheets in the file. A short-cut for 
bringing up the Index dialog itox is to double- 

20 dick on the index position indicator. 

• 3 Create 

The Sheet CSreate commsmd tarings up a dialog box 
which allows the user to create a new sheet 
ho&ta[inisui M name 
25 "Untitled". Change the name with the Sheet Edit 

command or double click on the Sheet Name 
indicator. 

• Delete 

The Sheet Delete command brings up a dialog box 
30 whicA allow the user to delete the sheet that is 

currently displayed. The user must confirm the 
deletion as a safeguard. 

• Bdit 

The Sheet Edit command displays a dialog box that 
35 lets the user enter a sheet name and background 

color, turn display of grid lines on and off, and 
adjust the grid size. A short-cut for bringing up 
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the Sheet Edit dialog box is to double-click on 
the sheet name. 

MODS MENU 

Use the Mode Menu to change the highlighting mode in 
5 Page Fragment objects. Each pkge fragment implements the 
basic highlighting facilities used in Telerate displays to 
indicate which characters on the source page have changed. 
The available modes are: 

• Hone 

10 No highlighting of changes is performed. 

• Mode J - Kuaerio Highlighiflng 

The numeric cheuractei^s which have chemged in the 
most recent update within the region shown by this 
fragment sure shown in reverse colors. 
15 • Mode R - Line Highlighting^ 

The line containing tihie most recent changie 
within the region shown by this fragment Is 
shown in reverse coloirs. 

• Mode H - J^ceuamlated mmerlo Highlighting 

20 The numeric characters which have chamged since the 

last mode : change or hig^ight clezur are shown din 
reverse colors. . j 

• Mode F Accumulated Line Highlighting 

The lines which have chemged since the most recent 
25 mode chemge or highlighting clecu: core sliown in 

reverse colors. 

• Mode Single - used for single fields 

The numeric character^ whi^ have changed in the 
most recent update anywhere, on the source page are 
30 shown in reverse colors. 

In general, use the Modes J through F when showing a 
large region of the source page. The highlighting will 
therefore apply to just this [ region, and will not be 
affected by updates outside this region. Use the single 
35 Mode when showing a page broken up into a number of small 
page fragments, such as one for each price. This way the 
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highlighting will be based on the most recent update 
anywhere on the source page (if the user had selected mode 
J for the small fragment, the highlights would remain until 
there was another update in that same small region) • 
5 Note that the highlighting is cleared for the selected 

objects whenever the mode menu is used. For instance, if 
Mode H is in effect and a number of highlights have 
accumulated, select Mode H again to clear the highlights and 
preserve the mode. 

, . 10 . Clearing of highUghts cam also be accomplished tdtt 
a script, see the Scripts section for more detail. 
Font Menu - 

Use the Font Menu to chang^^ the font used in selected 
V objects. The default font is a small fixed-width font. The 

15 elements of the font menu are defined by your system 
administrator, and may be changed when other fonts become 
available. Not all fonts are provided on all X Window 
• _ System implementations. Therefore, the program determines 

which of the requested fonts^ are not available, and 
20 indicates those in gray (disabled) items. The current font 
is indicated by ei black dot rtextf to its name. 

Note that if the selected object was made on another 

^^^^^^.^^^^^^^^^ 

there may be no current font indicated on the menu. 
25 Pan Menu 

Use the Pen Menu to specijfy the foregoing color of 
selected items. The default color is black. This is the 
color of the text or lines in the object. The current 
foreground color is indicated by a black dot next to its 
30 name. 

Border Menu 

Use the Border Menu to specify the size of the border 
around selected items. The default is one pixel. Wider 
borders waste some screen space but they are more attractive 
35 and easier to manipulate with the mouse. The current border 
size is indicated by a black dot next to its name. The 
lower portion of this menu specifies the border color of the 
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object. The current border color is indicated with a black 
dot next to its name. 

Note that the border color and width of buttons cannot 
be changed. 
5 Fill Kenu 

Use the Fill Menu to specify the background color of 
selected items. The default color is white. The current 
background color is indicated by a black dot next to its 
name. • — .-4- 

IQ Note on Use of variable-Width Fonts 

Font are divided into two types: fixed and variable. 
Fixed width fonts have all ch€uracters on the same size, 
^ * while variable Vidth fonts dr-]e' spaced propprtionally. Using 
variable width fonts on Quotes, Tickers, vor Page Fragments 
15 will have some unusual effects, because each of those 
objects are organized around a row-column grid, or matrix, 
or chsuractex^s. - ^ i ^ 

The character grid laydtit facility must allocate space 
for a grid of characters big enough to hold the biggest 
20 chciracter in the font, such 'a^^ . the letter ?W'. Thus it will 
often make itself wider than it appears to need to be. 
. -lJiS^Sg^>l^^tii^ Of objects is ^ 

reduced, the character grid Ikyout facility will compute how 
" many columns of the bigg^t^-iehteacter will fit, and show- 
2S only that number of character. -^This can often be deceptive .- 
It is preferable to use only fixed-width fonts on these 
types of objects. Not only will this avoid the above 
effect, but multi-line pagf<e fragments and quotes will 
continue to have their character columns lined up, as on the 
30 source page, since fonts vary^ from system to system, contact 
the System Administrator for information on which fonts are 
vari2J>le-width. 

HOW TO BUTLD THE MarketSheet? PROGRAM 
0VBRV3;EW 

35 There are two stages. The first stage builds the 
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Widget get, called Strata, which is used by the application. 
This stage relies only on availability of the standard X11R3 
distribution of the X Window System API library and the X 
Window System X Toolkit API library, both of which are 
5 distributed by the MIT X Consortium, and the TIB API 
libraries. ' 

The second stage is to build MarketSheet"" itself, which 
uses the Strata widget get library, the TIB API libraries, 
. and the X. Window System libraries. . . 

10 yK^CT phasb; 

The following files axB used to build the Strata library: 

Axis.c 

AxiB.h 

AxisP.h 

15 Basic.h ' ^ 

BasicP.fa 
Box.c 

BoacP.h 

1 ■• 'I 

20 Button .c 

Button .h 

ButtonP.h -#;>f 
CharGrid.c 

25 CharGrldP.h 
Converters .c 

""' converters .h - / ^ 

• DBoard.c' 

OBoard.h 
30 DBoardP.h 

Dialogic 

Dialog.h 

DialogP.h 

Gadget .c 
35 Gadget. h 

Gadget? .h 

GraphOata.c 

GraphData.h ' 
GraphDataP.h 
40 GraphMgr.c 
GraphMgr.h 
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GraphHgrP.h 
GraphView.c 
GraphView*.h 
GraphViewP.h 
5 Highlight* c 
Label. c 
Label .h 
LabelP.h 
List.c 

10 List.h 
ListP.h 
Kanager.c 
Menu.c 
Kenu.h. . 

15 uenuBar.c 
MenuBar.h 
HenuBarP.h 
lienuP^h 
Parimitive.c 

20 Header .c 
Reader .h . 
5election»e 
a^eztEdit.c 
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TextEdit. h 



■ Traversal, c . --^ 

Writer. h 



30 lib name « libetrate.a 

lib nembere » Primitive.o Manager.o Traversal.o Highlight.o 
Selection* o 



Converters. o Reader.b Hriter.o Gadget.o Label.o 
Box.o DBoard.o Dialog.o HenuBar.o Kenu.o List.o 



\ 

35 Button.o \ 
TextEdit .o \ 

CharGrid.o Axis.o GraphView.o GraphData.o GrapbMgr.o 
S(lib name) z S(lib_meiiiber8) 

40 SgCOKD PHASE 

The following files are used to build the MarketSheet" applications 
Box.c 
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Box.h 
BoxP.h 
Button* c 
Button. h 
5 ButtonP.h 
CharGrid.c 
CharOrid.h 
CharGridP.h 
DSAxis.c 
10 DSAxig.h 
. . DSAxisP.h 
DSQraphData.c 
DSGraphData.h 
DSGr aphDat aP » h 
15 DSGraphVievr.c 
DSGraphView. h 
DS6raphViewP.h 
Fragment .c 
Fragment .h 
20 Fragment? .h 
Manager .c 
^ PlaneMgr.c - 
PlaneMgr.h 
PlaneMgrP.h 
25 PubliBher. c 
Publisher. h 
PublisherP.h 
Qaote'.o * 7 
Quote .h 
. 30 QuoteP.h 
Reader. c 
Subscription • c 
Subscription • h 
Subscript ionP • h 
35 TBAxis.c 
TBAxis.h 
TBAxisP.h 
TBGraphData*c 
TBGr aphDat a • h 
40 TBGraphDataP.h 
TBGraphView. c 
TBGraphView.h 
TBGraphViewP. h 
Table, c 
45 Table, h 
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TableP.h 

Ticker. c 
Ticker. h 
TickerP.h 
5 TimeGrid.e 
TimeGrid.h 
TineGridP.h 
bits .arrow 
bits .button 
10 bits .clone 
bits.dsgraph 
bits . fragment 
bits .global 
bits. grid 
15 bits. label 

bitfif • publisher 
bits, quote 
bits.table 
bits.tbgraph 
20 bits. ticker 
bricks .bits 
button. c 
\ ' dsgraph^c 

files .c 
f v2 5 - fragment . cv • - 

. global .c 
Ti itesis.c 
•^^ '*"label.c" 
" menus, c 

30 mondrian.bits 
meney.bits 
ms.h 
ms23.c 

msDefaults.cf 
3 5 msBmpty . of 
msNTib.cf 
page.h . 

pagehahdler • c . 

pagemap.c 
40 pagemap.h 

publisher. e 

quote. c 

script. c 

sheets .c 
45 stylemap.c 
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Btylemap.h 
table .c 
tbqpraph.c 
tib.c 
5 tib.h 
ticker* c 
time.e 



Makefile for Second Phase (using GNUmake program): 

objects = Reader.o Manager.o PlaneMgr.o TimeGrid.o CharGrid.o Box«o 

..IP.. ...... ..,.„,^.-.;;.BMtton.p\.^.. /. 

^ tiU>.o tijM.o mnus.^ 
script.o Btylemap.o label. o Subscription .o Qaote.o quote.o 

\ 

Ticker.o ticker.o pagemap.o pagehandler.o \ 
15 Fragment .6 fragment .o \ 

TBAxig.o TBGraphView^o TBGraphOata.p tbgraph.o DSAxig.o \ 

DSGraphView.o DSGraphData.o dsgraph.o Publisher.o 
publisher .o \ 

Table. o table.o button.o global.o 
20 libs - -Inrti -Irti -Itibinfo -Imc^p new -Indsg -Imsa -Isags -Iforms 

-leventx -Iciutil -Istrate -Itss -lutil -IXt - 1X11 
m823: $( objects) $(lib8) 

Although the invention has been described in terms of 
25 the preferred and several alternative embodiments described 
herein, those skilled in the art will appreciate other 
embodiments and modifications which can be made without 
departing from the spirit and scope of the teachings of the 
invention. All such modifications are intended to be 
30 included within the scope of the claims appended hereto. 
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nhat is claimed is: 

1. An apparatus for ^creation of user defined video 
displays showing the values of real time data generated by 
a complex system, comprising: 
5 a computer means for storing and executing one or 

more programs; 

network meems for; coupling said computer means to 
a^ system being monitqred by receiving real time data 

. .and... fpr,: „ta:M.apdLtting.i^ P^^? ^^^ ^ 

10 system; 

a display coupl4d to said computer means for 
displaying the results: of processing by said programs; 
and .6 

wberein said , oije or more programs include 
15 composition meams for a^ccepting commands from a user to 

create instances of different classes of active objects 
which display on sdid display either real-time, 
chemging data generated by said system being monitored 
or alphanumeric data Entered by the user in a format 

^ 20 and style ^elected Jpy ii^4d_us<^ generating one 

or more active objects for storing real-^time data 
. V. ,w.. >v and/or: I djM;a,en^^ ftser ^and associated^ 

maps defining which o3|.said data is to be displayed, 
and where and how sjai^^ is to be displayed, and 

25 having associated display objects for storing internal 

compute data representations of the data to be 
displayed in accordance with said style map, and 
including meems to request and receive real-time data 
requested by said user and to update the internal 
30 computer data representations of the data to be 

displayed with new values for the real time data 
selected by said user for display. 

2. In a computing ^vironment including a system 
generating real time data to be monitored, at least one 
35 computer coupled to said system by a communication path and 

. -1 
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cojmnunication software to monitor said system via data 
displayed on a display, and one or more programs for 
controlling the processing of at least one said computer, 
the is^rovement comprising one or more programs for creating 
5 a (^amically changeable document on said display having a 
user defined layout and having user defined display objects 
displayed at user defined locations, said one or more 
programs comprising: 

label means for providing a ' text layout tool 
^° accessible by a user siifch that one more user def ined 

^^^s of user defined text may be established in the 
user defined layout for said dynamically changeable 
document; and 

real time data means for providing a layout tool 
15 accessible by a user such that one ot more user defined 
areas of said dynamically changeable document may be 
designated by said user to always s^dw the current and 
dynamically changeable value of any one or more user 
'"'■'"'••••••■■■■•"■""■•■'defined ltems--of '-real-titt^ '^M^'^'-^"'-' ••■—v- k-.-.-.-... 

"■' ■ ■.! 

• rr • 

20 3. The apparatus of claim 2 further comprising graph 

means for providing a layout "tool access|bie"by a user such 
that one or more user designated areas ol said dynamically 
changeable adcumeht may be deHned ' tc| alway^ show the 
dynamically changeable value of one or iiore user def ined 

25 items of real time data as a graph showing the history and 
current value of the changing value of said user defined 
items of real time data versus time. 

4. The apparatus of claim 2 further comprising ticker 
means for providing a layout tool accessible by a user such 

30 that one or more user designated areas of said dynamically 
changeable document may be defined to always show the 
dynamically changeable value -of one or more user defined 
items of real time data as the current price for each issue 
for all trades in a user specified set of financial 

35 securities. 
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5. The apparatus of claim 2 further comprising page 
fragment means for providing a layout tool accessible by a 
user such that one or more user designated areas of said 
dynamically ch€mgeable document may be defined to always 

5 show the dynamically changeable value of one or more user 
defined item^ of real time^ data in the form of user 
designated portions of one or- more pages of financial data 
from a user defined, page oriented flnamcial information 
service which publishes said financial data via said 
10 cojm^ _ J 

6. The appauratus of cliim 2 further comprising page 
means for providing a layout; tool whereby a plurality of 
pages may be defined, each haying a user defined layout of 
user defined text and each capable of having user defined 

15 items of real time data displayed in user designated 
locations thereon. 

7. I3ie appsurattis of claLim 2 further comprisx^ig: 
alajdn means tor jp0yxding a ' tool which' may be " 

invoked by the user to e&tablish alarm limits which are 
20 associate^d with one or J&bre of said user designated 

items of v^said real time ^.|(ata, said alainn limits ^^^n? 
compared with the value bf said corresponding item of 
real time data from time to time and for setting ah 
alert status when any one of said aleuna limits is 
25 exceeded; €md 

script mesms coupled to each said alarm limit for 
storing and executing ^user defined sequences of 
commemds to cause a user defined sequence of events, to 
occur whenever the corresponding alarm limit is 
30 exceeded. 

8. The apparatus of claim 3 further comprising alarm 
meems coupled to said graph f means for providing a tool 
whereby a user may define up to two active trend lines, 
typically upper and lower limits, for the value depicted on 
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each said user defined graph, and for coiaparing each new 
graph point displayed upon receipt of an update to the 
corresponding real time data to any active user defined 
trend lines for the corresponding graph, and if a limit 
5 established by an active trend line is equalled or exceeded, 
for generating an alert signal. 

9. The apparatus of claim 2 wherein said real tdLme 
data means includes quote means for providing a tool which 
may be invoked by a user to locate at user defined locations 
10 on said dynamically changeable document one or more quote 
active objects, each said quote active object for receiving 
emd displaying the current price for a uker designated 
financial issue at said designated location of said 
dynamically changeable document. 



15 lb. The apparatus of claim 2 further comprising: 

button means for providing a tool which may be 
liSi^^ iiy €He user to locia^ 
^ bbjects abuser definable locations o^^ 

changeable document, and ' 1=^ 

20 further comprising script means associated with 

each said button means fbr storing and executing a user 
defined sequence of commands which cause^a user defined 
sequence of events to bccuif, each said script means 
coupled to a corresponding button active object such 

25 that when a button active object is selected in any 

m2mner, said associated script means is invoked and the 
corresponding script of commemds is executed. 

11. The apparatus of claim 2 wherein ?aid real time 
data means includes means to create an active object in 
30 memory of at least one said computer for each said user 
designated item of real time data, each said active object 
having an associated list of properties and operations which 
can be invoked by a user to change the values of various 
properties of the object, wherein each operation can be 
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invcdced by user entry of a command to identify said active 
object and stari: the operation and pass an fiorgianent to the 
operation for use in chamging^ the properties of said active 
object, 

5 12 . The app2u:atus of cliim 11 wherein each said active 

object is represented in memory by a record containing the 
values for each said property^ and a pointer to a library of 
programs which carry put the ciperatipns associated with that 

■ -active ,.object^•« ..v- ^ .i^; , , , .... ..„.^,.. 

10 13 • The apparatus of claim 12 wherein each said aptive 

object comprises: 

a data object mea|is for storing the internal 
, . . .computer representation a set of data items about 
the subject associpit^^^^ with that particular data 
15 object; 

. data specif yijig partic^lcir ones of the data items 
stored in said data obj^t to display and where and how 
■ ..^-to^i^play .thes^- 4ata,..x:|^ 4|j-- 
20 * scrj^n rendering M^^s for rendering. informa;tion 

.on.. said^ .display;,. ^. .......... \ --m. . 

, ^ a display^ object p^ans^^ f^ extracting the data 

, specified by^sai^ styl,e,j^p mesms from said data object 

means and for sending said extracted data an 
25 appropriate rendering commauid based upon said style 

data to said screen rendering means for rendering said 
data on said display in accprdemce with said s^le 
data; ^•/f- 

event trigger means for storing user defined event 
30 trigger data specifying the conditions under which the 

user desires further action to occur; and 

event script means^ for storing a user defined 
script of actions which are to be ceurried out in a user 
defined sequence if one of the event trigger conditions 
35 is met. 
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14. The apparatus of claim 13 wherein said display 
object means includes style processor means for receiving 
data updates comprised of the new value for one or more 
items of said real time data associated with one or more 
5 active objects displayed on said dynamically changeable 
document, and for extracting the corresponding data items 
whose values have been updated from said data object means, 
and for updating the extracted data with its new values and 
storing the updated values in said t^spiay object means in 
10 accordance with said style data stioWd in said style map 
meems, and for comparing the updated values for said data to 
any event trigger data stored in sai^ event trigger means, 
arid for computing special effects t6 be displayed on said 
display according to said style data if any event trigger 
15 has occurred, and for updating the?^ data stored in said 
display object means if any special effects have been 
triggered by said update, and f or sehding appropriate data 
to said screen rendering means to^render any triggered 
"■"■^^sj^e^iareffedesr":-^-^'^'^ , ..--..i^.,.^^>^-^x:.-^...^...^,.... . ... -.v.-- 

^9. . J. '^^^ apparatus of claim 3 *rk%rein said graph means 

includes means for scaling each axip'%ep2u:ately • 

16. The apparatus Of claim 3 w^fesrein said graph means 
includes means for displaying the n^eric values on each 
axis of said graph for any particular^int on the graplx,,for 

25 any particular point on the graph w&ich has been graphically 
selected. 

17. The apparatus of claim 3 wherein said graph means 
includes means for causing automatic rescaling of the time 

30 axis for any graph wherein one of the axes has been user 
defined to show time. 

18. The apparatus of claim 3 wherein said graph means 
includes means for providing a tool whereby a user may 
graphically designate any two points on a graph so as to 
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designate a trend line. 

19. The appcoratus of claim 3 wherein said graph means 
includes zoom means for allowing a user to enlarge the view 
. of any user designated portion, of any said graph. 

5 20. The apparatus of claim 3 wherein said graph means 

includes merge means for allowing a user to designate at 
least two items of said real time dat^. to have their values 

, graphed on the ^same graph against the same time axis or 
other measure. 

A- 

10 21. The apparatus of clai^ 7 wherein said sdript means 

conqdrises: i 

meems for selection of active objects; 

means for editing selected active objects; 

means for moving and resizing of selected active 



15.^., objects; ^- _ ■-..i^. V 

means for moving betwjsen pages of said dynamically 



J" 



changeeU^le document; 



^ means , fo selected pagej! of saxd 

dynamically chemgeable document; 

20 means for causing au^lible signals, for ^ causing a 

cdmiQand . of . another progrson such as an operating system 
program to be executed ^jmid for pausing a user 
designated amount of time; and 

means for controlling the display of the computing 

25 environment such as displaying or not displaying the 

available tools for creating and editing said pages of 
said dynamically changeeODle document or displaying or 
not displaying alignment aids for layout of said pages 
of said dynamically changeable document such as grid 

30 lines. 

22. The appeuratus of cla:^ 1 or 2 or 3 or 4 or 5 or 6 
or 7 or 8 or 9 or 10 or 13 or 14 or 15 or 16 or 17 or 18 or 
19 or 20 or 21 further comprising publishing means for 
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providing a tool whereby a user cam designate any portion of 
any page of said dynamically changeable document to be 
published via said communication software and said 
communication path to other processes running on any said 
5 computer. 

23. The apparatus of claim 10 wherein said script 
means comprises: 

mecms for selection of active^ objects; 
means for editing selected active objects; 
0 means for moving and resizing ot selected active 

objects; 

means for moving between pages' of said dynamically 
chsmgeable docviment; 

means for editing a seiec^ted page of said 
> d^amically changeable document; 

means f cr cauisiiig audible si'^als, for causing a 
command of another program such as ian operating system 
''r '•■ ''"prcgraiii • to • be"' "dkecuted- " ■■'and-''-'-'f tSr^- - patusing a'" " us^-" 
■-,r:s- . designated-'amount'^ief ■■■t^bBBt^ -and"'-'*'-''*^ ' ■ -s- • 

^ means for controlling the di^ay of the computii^ 

environment sue* as displaying orTnot 
^ ' iv^tmM tools fcir-'ct^ih^ kh.l^i^ 

said dynamicailiy chsmgeable docuidfit or displaying 6i^^ 
^ hot diisplaying alignment aids for layout of said pag^ 
25' of said dynamically changeable document such as grid 

24. The apparatus of claim 2 further comprising table 
tool means for providing a tool to create, user defined table 
tool objects for display of useful reference information 
30 such as the names of commonly used pagis of page oriented 
services or securities, etc. 



25. The apparatus of claim 21 or 23 wherein said 
script means further con^rises glossary iseans for providing 
a tool whereby a user may enter new commands which are 



wo 92/12488 



PCr/US91/09811 



- 82 - 

available for execution during a user defined script of 
actions. 

26. The apparatus of claim 2 further comprising means 
for displaying a menu of universal commands which can be 
5 used to edit or manipulate all pages and all active objects 
displayed on any page of skid dynamically chemgeable 
document^ and to display a pop-?up mtou of further commands 
associated with any command from said menu of imiversal 
commemds. •■ -4 

'A- 

10 27. The apparatus of claip 2 or 3 or 4 or 5 or 9 or 10 

or 26 further con^rising means for displaying all tool means 
as icons which may be graphicaX'^jLy selected. 

28. The apparatus of claijii 2 further comprising means 
for highlighting the display of data that has changed. 

J5< . . . . W.29 . .The. apparatus of clai^ . 
; for displaying said active ob^Bcts in layers, and- further 

comprising mezoiis f or^cdiaiiging it*e the lay^s*^ . i 

^30. The apparatus of clai4 2 %rtierein each sai^page of 
said dynsmically cdiangeable idocwent is simult^^ously 
20 displayed in its own s^arate w4Jidow. . 



31. The apparatus of claim 2 wherein said 
communication software implements a subscription paradigm 
such that application programs linked thereto need only send 
a subscription request on a subject to said communication 
25 software and said communication softwzure than carries out 
appropriate processing to locate a source for the desired 
information r communicate with that source and enter a 



data is constantly sent via 
communication softweure £uid 



subscription such that real time 
said communication path to said 
30 passed therefrom to said real time data meams where the 
updated values thereof are displayed as they aanrive, and 
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wherein said real time data means includes means, for passing 
subscription requests on user designated subjects 
represented by the real time data associated with each said 
active object to said communication software as a 
5 subscription request so as to invoke the appropriate 
processing to cause real time data to start flowing to 
update the data of each said active object and the displayed 
value thereof. 
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